123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143 |
- namespace SevenZip
- {
- using System;
- using System.Collections.Generic;
- using System.Globalization;
- using System.IO;
- using System.Runtime.InteropServices;
- #if NET472 || NETSTANDARD2_0
- using System.Security.Permissions;
- #endif
- using FILETIME = System.Runtime.InteropServices.ComTypes.FILETIME;
- #if UNMANAGED
- // ReSharper disable file ConvertToAutoProperty - For UWP compatibility.
- /// <summary>
- /// The structure to fix x64 and x32 variant size mismatch.
- /// </summary>
- [StructLayout(LayoutKind.Sequential)]
- internal struct PropArray
- {
- readonly uint _cElems;
- readonly IntPtr _pElems;
- }
- /// <summary>
- /// COM VARIANT structure with special interface routines.
- /// </summary>
- [StructLayout(LayoutKind.Explicit)]
- internal struct PropVariant
- {
- [FieldOffset(0)] private ushort _vt;
- /// <summary>
- /// FILETIME variant value.
- /// </summary>
- [FieldOffset(8)] private readonly FILETIME _fileTime;
- /// <summary>
- /// The PropArray instance to fix the variant size on x64 bit systems.
- /// </summary>
- [FieldOffset(8)]
- private readonly PropArray _propArray;
- [FieldOffset(8)] private IntPtr _value;
- [FieldOffset(8)] private uint _uInt32Value;
- [FieldOffset(8)] private int _int32Value;
- [FieldOffset(8)] private long _int64Value;
- [FieldOffset(8)] private ulong _uInt64Value;
- /// <summary>
- /// Gets or sets variant type.
- /// </summary>
- public VarEnum VarType
- {
- private get
- {
- return (VarEnum) _vt;
- }
- set
- {
- _vt = (ushort) value;
- }
- }
- /// <summary>
- /// Gets or sets the pointer value of the COM variant
- /// </summary>
- public IntPtr Value
- {
- get => _value;
- set => _value = value;
- }
- /// <summary>
- /// Gets or sets the UInt32 value of the COM variant.
- /// </summary>
-
- public uint UInt32Value
- {
- get => _uInt32Value;
- set => _uInt32Value = value;
- }
- /// <summary>
- /// Gets or sets the UInt32 value of the COM variant.
- /// </summary>
-
- public int Int32Value
- {
- get => _int32Value;
- set => _int32Value = value;
- }
- /// <summary>
- /// Gets or sets the Int64 value of the COM variant
- /// </summary>
-
- public long Int64Value
- {
- get => _int64Value;
- set => _int64Value = value;
- }
- /// <summary>
- /// Gets or sets the UInt64 value of the COM variant
- /// </summary>
-
- public ulong UInt64Value
- {
- get => _uInt64Value;
- set => _uInt64Value = value;
- }
- /// <summary>
- /// Gets the object for this PropVariant.
- /// </summary>
- /// <returns></returns>
- public object Object
- {
- get
- {
- #if NET472 || NETSTANDARD2_0
- var sp = new SecurityPermission(SecurityPermissionFlag.UnmanagedCode);
- sp.Demand();
- #endif
- switch (VarType)
- {
- case VarEnum.VT_BSTR:
- return Marshal.PtrToStringBSTR(Value);
- case VarEnum.VT_EMPTY:
- return null;
- case VarEnum.VT_FILETIME:
- try
- {
- return DateTime.FromFileTime(Int64Value);
- }
- catch (ArgumentOutOfRangeException)
- {
- return DateTime.MinValue;
- }
- default:
- var propHandle = GCHandle.Alloc(this, GCHandleType.Pinned);
-
- try
- {
- return Marshal.GetObjectForNativeVariant(propHandle.AddrOfPinnedObject());
- }
- catch (NotSupportedException)
- {
- switch (VarType)
- {
- case VarEnum.VT_UI8:
- return UInt64Value;
- case VarEnum.VT_UI4:
- return UInt32Value;
- case VarEnum.VT_I8:
- return Int64Value;
- case VarEnum.VT_I4:
- return Int32Value;
- default:
- return 0;
- }
- }
- finally
- {
- propHandle.Free();
- }
- }
- }
- }
- /// <summary>
- /// Determines whether the specified System.Object is equal to the current PropVariant.
- /// </summary>
- /// <param name="obj">The System.Object to compare with the current PropVariant.</param>
- /// <returns>true if the specified System.Object is equal to the current PropVariant; otherwise, false.</returns>
- public override bool Equals(object obj)
- {
- return obj is PropVariant variant && Equals(variant);
- }
- /// <summary>
- /// Determines whether the specified PropVariant is equal to the current PropVariant.
- /// </summary>
- /// <param name="afi">The PropVariant to compare with the current PropVariant.</param>
- /// <returns>true if the specified PropVariant is equal to the current PropVariant; otherwise, false.</returns>
- private bool Equals(PropVariant afi)
- {
- if (afi.VarType != VarType)
- {
- return false;
- }
- if (VarType != VarEnum.VT_BSTR)
- {
- return afi.Int64Value == Int64Value;
- }
- return afi.Value == Value;
- }
- /// <summary>
- /// Serves as a hash function for a particular type.
- /// </summary>
- /// <returns> A hash code for the current PropVariant.</returns>
- public override int GetHashCode()
- {
- return Value.GetHashCode();
- }
- /// <summary>
- /// Returns a System.String that represents the current PropVariant.
- /// </summary>
- /// <returns>A System.String that represents the current PropVariant.</returns>
- public override string ToString()
- {
- return "[" + Value + "] " + Int64Value.ToString(CultureInfo.CurrentCulture);
- }
- /// <summary>
- /// Determines whether the specified PropVariant instances are considered equal.
- /// </summary>
- /// <param name="afi1">The first PropVariant to compare.</param>
- /// <param name="afi2">The second PropVariant to compare.</param>
- /// <returns>true if the specified PropVariant instances are considered equal; otherwise, false.</returns>
- public static bool operator ==(PropVariant afi1, PropVariant afi2)
- {
- return afi1.Equals(afi2);
- }
- /// <summary>
- /// Determines whether the specified PropVariant instances are not considered equal.
- /// </summary>
- /// <param name="afi1">The first PropVariant to compare.</param>
- /// <param name="afi2">The second PropVariant to compare.</param>
- /// <returns>true if the specified PropVariant instances are not considered equal; otherwise, false.</returns>
- public static bool operator !=(PropVariant afi1, PropVariant afi2)
- {
- return !afi1.Equals(afi2);
- }
- }
- /// <summary>
- /// Stores file extraction modes.
- /// </summary>
- internal enum AskMode
- {
- /// <summary>
- /// Extraction mode
- /// </summary>
- Extract = 0,
- /// <summary>
- /// Test mode
- /// </summary>
- Test,
- /// <summary>
- /// Skip mode
- /// </summary>
- Skip
- }
- /// <summary>
- /// Stores operation result values
- /// </summary>
- public enum OperationResult
- {
- /// <summary>
- /// Success
- /// </summary>
- Ok = 0,
- /// <summary>
- /// Method is unsupported
- /// </summary>
- UnsupportedMethod,
- /// <summary>
- /// Data error has occurred
- /// </summary>
- DataError,
- /// <summary>
- /// CrcError has occurred
- /// </summary>
- CrcError,
- /// <summary>
- /// File is unavailable
- /// </summary>
- Unavailable,
- /// <summary>
- /// Unexpected end of file
- /// </summary>
- UnexpectedEnd,
- /// <summary>
- /// Data after end of archive
- /// </summary>
- DataAfterEnd,
- /// <summary>
- /// File is not archive
- /// </summary>
- IsNotArc,
- /// <summary>
- /// Archive headers error
- /// </summary>
- HeadersError,
- /// <summary>
- /// Wrong password
- /// </summary>
- WrongPassword
- }
- /// <summary>
- /// Codes of item properties
- /// </summary>
- internal enum ItemPropId : uint
- {
- /// <summary>
- /// No property
- /// </summary>
- NoProperty = 0,
- MainSubfile,
- /// <summary>
- /// Handler item index
- /// </summary>
- HandlerItemIndex,
- /// <summary>
- /// Item path
- /// </summary>
- Path,
- /// <summary>
- /// Item name
- /// </summary>
- Name,
- /// <summary>
- /// Item extension
- /// </summary>
- Extension,
- /// <summary>
- /// true if the item is a folder; otherwise, false
- /// </summary>
- IsDirectory,
- /// <summary>
- /// Item size
- /// </summary>
- Size,
- /// <summary>
- /// Item packed sise; usually absent
- /// </summary>
- PackedSize,
- /// <summary>
- /// Item attributes; usually absent
- /// </summary>
- Attributes,
- /// <summary>
- /// Item creation time; usually absent
- /// </summary>
- CreationTime,
- /// <summary>
- /// Item last access time; usually absent
- /// </summary>
- LastAccessTime,
- /// <summary>
- /// Item last write time
- /// </summary>
- LastWriteTime,
- /// <summary>
- /// true if the item is solid; otherwise, false
- /// </summary>
- Solid,
- /// <summary>
- /// true if the item is commented; otherwise, false
- /// </summary>
- Commented,
- /// <summary>
- /// true if the item is encrypted; otherwise, false
- /// </summary>
- Encrypted,
- /// <summary>
- /// (?)
- /// </summary>
- SplitBefore,
- /// <summary>
- /// (?)
- /// </summary>
- SplitAfter,
- /// <summary>
- /// Dictionary size(?)
- /// </summary>
- DictionarySize,
- /// <summary>
- /// Item CRC checksum
- /// </summary>
- Crc,
- /// <summary>
- /// Item type(?)
- /// </summary>
- Type,
- /// <summary>
- /// (?)
- /// </summary>
- IsAnti,
- /// <summary>
- /// Compression method
- /// </summary>
- Method,
- /// <summary>
- /// (?); usually absent
- /// </summary>
- HostOS,
- /// <summary>
- /// Item file system; usually absent
- /// </summary>
- FileSystem,
- /// <summary>
- /// Item user(?); usually absent
- /// </summary>
- User,
- /// <summary>
- /// Item group(?); usually absent
- /// </summary>
- Group,
- /// <summary>
- /// Bloack size(?)
- /// </summary>
- Block,
- /// <summary>
- /// Item comment; usually absent
- /// </summary>
- Comment,
- /// <summary>
- /// Item position
- /// </summary>
- Position,
- /// <summary>
- /// Item prefix(?)
- /// </summary>
- Prefix,
- /// <summary>
- /// Number of subdirectories
- /// </summary>
- NumSubDirs,
- /// <summary>
- /// Numbers of subfiles
- /// </summary>
- NumSubFiles,
- /// <summary>
- /// The archive legacy unpacker version
- /// </summary>
- UnpackVersion,
- /// <summary>
- /// Volume(?)
- /// </summary>
- Volume,
- /// <summary>
- /// Is a volume
- /// </summary>
- IsVolume,
- /// <summary>
- /// Offset value(?)
- /// </summary>
- Offset,
- /// <summary>
- /// Links(?)
- /// </summary>
- Links,
- /// <summary>
- /// Number of blocks
- /// </summary>
- NumBlocks,
- /// <summary>
- /// Number of volumes(?)
- /// </summary>
- NumVolumes,
- /// <summary>
- /// Time type(?)
- /// </summary>
- TimeType,
- /// <summary>
- /// 64-bit(?)
- /// </summary>
- Bit64,
- /// <summary>
- /// BigEndian
- /// </summary>
- BigEndian,
- /// <summary>
- /// Cpu(?)
- /// </summary>
- Cpu,
- /// <summary>
- /// Physical archive size
- /// </summary>
- PhysicalSize,
- /// <summary>
- /// Headers size
- /// </summary>
- HeadersSize,
- /// <summary>
- /// Archive checksum
- /// </summary>
- Checksum,
- Characts,
- Va,
- Id,
- ShortName,
- CreatorApp,
- SectorSize,
- PosixAttrib,
- SymLink,
- Error,
- /// <summary>
- /// (?)
- /// </summary>
- TotalSize,
- /// <summary>
- /// (?)
- /// </summary>
- FreeSpace,
- /// <summary>
- /// Cluster size(?)
- /// </summary>
- ClusterSize,
- /// <summary>
- /// Volume name(?)
- /// </summary>
- VolumeName,
- /// <summary>
- /// Local item name(?); usually absent
- /// </summary>
- LocalName,
- /// <summary>
- /// (?)
- /// </summary>
- Provider,
- NtSecure,
- IsAltStream,
- IsAux,
- IsDeleted,
- IsTree,
- Sha1,
- Sha256,
- ErrorType,
- NumErrors,
- ErrorFlags,
- WarningFlags,
- Warning,
- NumStreams,
- NumAltStreams,
- AltStreamsSize,
- VirtualSize,
- UnpackSize,
- TotalPhySize,
- /// <summary>
- /// Index of the Volume
- /// </summary>
- VolumeIndex,
- SubType,
- ShortComment,
- CodePage,
- IsNotArcType,
- PhySizeCantBeDetected,
- ZerosTailIsAllowed,
- TailSize,
- EmbeddedStubSize,
- NtReparse,
- HardLink,
- INode,
- StreamId,
- ReadOnly,
- OutName,
- CopyLink,
- NumDefined,
- /// <summary>
- /// User defined property; usually absent
- /// </summary>
- UserDefined = 0x10000
- }
- /// <summary>
- /// PropId string names dictionary wrapper.
- /// </summary>
- internal static class PropIdToName
- {
- /// <summary>
- /// PropId string names
- /// </summary>
- public static readonly Dictionary<ItemPropId, string> PropIdNames =
- #region Initialization
- new Dictionary<ItemPropId, string>(46)
- {
- {ItemPropId.Path, "Path"},
- {ItemPropId.Name, "Name"},
- {ItemPropId.IsDirectory, "Folder"},
- {ItemPropId.Size, "Size"},
- {ItemPropId.PackedSize, "Packed Size"},
- {ItemPropId.Attributes, "Attributes"},
- {ItemPropId.CreationTime, "Created"},
- {ItemPropId.LastAccessTime, "Accessed"},
- {ItemPropId.LastWriteTime, "Modified"},
- {ItemPropId.Solid, "Solid"},
- {ItemPropId.Commented, "Commented"},
- {ItemPropId.Encrypted, "Encrypted"},
- {ItemPropId.SplitBefore, "Split Before"},
- {ItemPropId.SplitAfter, "Split After"},
- {
- ItemPropId.DictionarySize,
- "Dictionary Size"
- },
- {ItemPropId.Crc, "CRC"},
- {ItemPropId.Type, "Type"},
- {ItemPropId.IsAnti, "Anti"},
- {ItemPropId.Method, "Method"},
- {ItemPropId.HostOS, "Host OS"},
- {ItemPropId.FileSystem, "File System"},
- {ItemPropId.User, "User"},
- {ItemPropId.Group, "Group"},
- {ItemPropId.Block, "Block"},
- {ItemPropId.Comment, "Comment"},
- {ItemPropId.Position, "Position"},
- {ItemPropId.Prefix, "Prefix"},
- {
- ItemPropId.NumSubDirs,
- "Number of subdirectories"
- },
- {
- ItemPropId.NumSubFiles,
- "Number of subfiles"
- },
- {
- ItemPropId.UnpackVersion,
- "Unpacker version"
- },
- {ItemPropId.VolumeIndex, "VolumeIndex"},
- {ItemPropId.Volume, "Volume"},
- {ItemPropId.IsVolume, "IsVolume"},
- {ItemPropId.Offset, "Offset"},
- {ItemPropId.Links, "Links"},
- {
- ItemPropId.NumBlocks,
- "Number of blocks"
- },
- {
- ItemPropId.NumVolumes,
- "Number of volumes"
- },
- {ItemPropId.TimeType, "Time type"},
- {ItemPropId.Bit64, "64-bit"},
- {ItemPropId.BigEndian, "Big endian"},
- {ItemPropId.Cpu, "CPU"},
- {
- ItemPropId.PhysicalSize,
- "Physical Size"
- },
- {ItemPropId.HeadersSize, "Headers Size"},
- {ItemPropId.Checksum, "Checksum"},
- {ItemPropId.FreeSpace, "Free Space"},
- {ItemPropId.ClusterSize, "Cluster Size"}
- };
- #endregion
- }
- /// <summary>
- /// 7-zip IArchiveOpenCallback imported interface to handle the opening of an archive.
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000600100000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface IArchiveOpenCallback
- {
- // ref ulong replaced with IntPtr because handlers often pass null value
- // read actual value with Marshal.ReadInt64
- /// <summary>
- /// Sets total data size
- /// </summary>
- /// <param name="files">Files pointer</param>
- /// <param name="bytes">Total size in bytes</param>
- void SetTotal(
- IntPtr files,
- IntPtr bytes);
- /// <summary>
- /// Sets completed size
- /// </summary>
- /// <param name="files">Files pointer</param>
- /// <param name="bytes">Completed size in bytes</param>
- void SetCompleted(
- IntPtr files,
- IntPtr bytes);
- }
- /// <summary>
- /// 7-zip ICryptoGetTextPassword imported interface to get the archive password.
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000500100000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface ICryptoGetTextPassword
- {
- /// <summary>
- /// Gets password for the archive
- /// </summary>
- /// <param name="password">Password for the archive</param>
- /// <returns>Zero if everything is OK</returns>
- [PreserveSig]
- int CryptoGetTextPassword(
- [MarshalAs(UnmanagedType.BStr)] out string password);
- }
- /// <summary>
- /// 7-zip ICryptoGetTextPassword2 imported interface for setting the archive password.
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000500110000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface ICryptoGetTextPassword2
- {
- /// <summary>
- /// Sets password for the archive
- /// </summary>
- /// <param name="passwordIsDefined">Specifies whether archive has a password or not (0 if not)</param>
- /// <param name="password">Password for the archive</param>
- /// <returns>Zero if everything is OK</returns>
- [PreserveSig]
- int CryptoGetTextPassword2(
- ref int passwordIsDefined,
- [MarshalAs(UnmanagedType.BStr)] out string password);
- }
- /// <summary>
- /// 7-zip IArchiveExtractCallback imported interface.
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000600200000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface IArchiveExtractCallback
- {
- /// <summary>
- /// Gives the size of the unpacked archive files
- /// </summary>
- /// <param name="total">Size of the unpacked archive files (in bytes)</param>
- void SetTotal(ulong total);
- /// <summary>
- /// SetCompleted 7-zip function
- /// </summary>
- /// <param name="completeValue"></param>
- void SetCompleted([In] ref ulong completeValue);
- /// <summary>
- /// Gets the stream for file extraction
- /// </summary>
- /// <param name="index">File index in the archive file table</param>
- /// <param name="outStream">Pointer to the stream</param>
- /// <param name="askExtractMode">Extraction mode</param>
- /// <returns>S_OK - OK, S_FALSE - skip this file</returns>
- [PreserveSig]
- int GetStream(
- uint index,
- [Out, MarshalAs(UnmanagedType.Interface)] out ISequentialOutStream outStream,
- AskMode askExtractMode);
- /// <summary>
- /// PrepareOperation 7-zip function
- /// </summary>
- /// <param name="askExtractMode">Ask mode</param>
- void PrepareOperation(AskMode askExtractMode);
- /// <summary>
- /// Sets the operation result
- /// </summary>
- /// <param name="operationResult">The operation result</param>
- void SetOperationResult(OperationResult operationResult);
- }
- /// <summary>
- /// 7-zip IArchiveUpdateCallback imported interface.
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000600800000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface IArchiveUpdateCallback
- {
- /// <summary>
- /// Gives the size of the unpacked archive files.
- /// </summary>
- /// <param name="total">Size of the unpacked archive files (in bytes)</param>
- void SetTotal(ulong total);
- /// <summary>
- /// SetCompleted 7-zip internal function.
- /// </summary>
- /// <param name="completeValue"></param>
- void SetCompleted([In] ref ulong completeValue);
- /// <summary>
- /// Gets archive update mode.
- /// </summary>
- /// <param name="index">File index</param>
- /// <param name="newData">1 if new, 0 if not</param>
- /// <param name="newProperties">1 if new, 0 if not</param>
- /// <param name="indexInArchive">-1 if doesn't matter</param>
- /// <returns></returns>
- [PreserveSig]
- int GetUpdateItemInfo(
- uint index, ref int newData,
- ref int newProperties, ref uint indexInArchive);
- /// <summary>
- /// Gets the archive item property data.
- /// </summary>
- /// <param name="index">Item index</param>
- /// <param name="propId">Property identifier</param>
- /// <param name="value">Property value</param>
- /// <returns>Zero if Ok</returns>
- [PreserveSig]
- int GetProperty(uint index, ItemPropId propId, ref PropVariant value);
- /// <summary>
- /// Gets the stream for reading.
- /// </summary>
- /// <param name="index">The item index.</param>
- /// <param name="inStream">The ISequentialInStream pointer for reading.</param>
- /// <returns>Zero if Ok</returns>
- [PreserveSig]
- int GetStream(
- uint index,
- [Out, MarshalAs(UnmanagedType.Interface)] out ISequentialInStream inStream);
- /// <summary>
- /// Sets the result for currently performed operation.
- /// </summary>
- /// <param name="operationResult">The result value.</param>
- void SetOperationResult(OperationResult operationResult);
- /// <summary>
- /// EnumProperties 7-zip internal function.
- /// </summary>
- /// <param name="enumerator">The enumerator pointer.</param>
- /// <returns></returns>
- long EnumProperties(IntPtr enumerator);
- }
- /// <summary>
- /// 7-zip IArchiveOpenVolumeCallback imported interface to handle archive volumes.
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000600300000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface IArchiveOpenVolumeCallback
- {
- /// <summary>
- /// Gets the archive property data.
- /// </summary>
- /// <param name="propId">The property identificator.</param>
- /// <param name="value">The property value.</param>
- [PreserveSig]
- int GetProperty(
- ItemPropId propId, ref PropVariant value);
- /// <summary>
- /// Gets the stream for reading the volume.
- /// </summary>
- /// <param name="name">The volume file name.</param>
- /// <param name="inStream">The IInStream pointer for reading.</param>
- /// <returns>Zero if Ok</returns>
- [PreserveSig]
- int GetStream(
- [MarshalAs(UnmanagedType.LPWStr)] string name,
- [Out, MarshalAs(UnmanagedType.Interface)] out IInStream inStream);
- }
- /// <summary>
- /// 7-zip ISequentialInStream imported interface
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000300010000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface ISequentialInStream
- {
- /// <summary>
- /// Writes data to 7-zip packer
- /// </summary>
- /// <param name="data">Array of bytes available for writing</param>
- /// <param name="size">Array size</param>
- /// <returns>S_OK if success</returns>
- /// <remarks>If (size > 0) and there are bytes in stream,
- /// this function must read at least 1 byte.
- /// This function is allowed to read less than "size" bytes.
- /// You must call Read function in loop, if you need exact amount of data.
- /// </remarks>
- int Read(
- [Out, MarshalAs(UnmanagedType.LPArray, SizeParamIndex = 1)] byte[] data,
- uint size);
- }
- /// <summary>
- /// 7-zip ISequentialOutStream imported interface
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000300020000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface ISequentialOutStream
- {
- /// <summary>
- /// Writes data to unpacked file stream
- /// </summary>
- /// <param name="data">Array of bytes available for reading</param>
- /// <param name="size">Array size</param>
- /// <param name="processedSize">Processed data size</param>
- /// <returns>S_OK if success</returns>
- /// <remarks>If size != 0, return value is S_OK and (*processedSize == 0),
- /// then there are no more bytes in stream.
- /// If (size > 0) and there are bytes in stream,
- /// this function must read at least 1 byte.
- /// This function is allowed to rwrite less than "size" bytes.
- /// You must call Write function in loop, if you need exact amount of data.
- /// </remarks>
- [PreserveSig]
- int Write(
- [In, MarshalAs(UnmanagedType.LPArray, SizeParamIndex = 1)] byte[] data,
- uint size, IntPtr processedSize);
- }
- /// <summary>
- /// 7-zip IInStream imported interface
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000300030000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface IInStream
- {
- /// <summary>
- /// Read routine
- /// </summary>
- /// <param name="data">Array of bytes to set</param>
- /// <param name="size">Array size</param>
- /// <returns>Zero if Ok</returns>
- int Read(
- [Out, MarshalAs(UnmanagedType.LPArray, SizeParamIndex = 1)] byte[] data,
- uint size);
- /// <summary>
- /// Seek routine
- /// </summary>
- /// <param name="offset">Offset value</param>
- /// <param name="seekOrigin">Seek origin value</param>
- /// <param name="newPosition">New position pointer</param>
- void Seek(
- long offset, SeekOrigin seekOrigin, IntPtr newPosition);
- }
- /// <summary>
- /// 7-zip IOutStream imported interface
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000300040000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface IOutStream
- {
- /// <summary>
- /// Write routine
- /// </summary>
- /// <param name="data">Array of bytes to get</param>
- /// <param name="size">Array size</param>
- /// <param name="processedSize">Processed size</param>
- /// <returns>Zero if Ok</returns>
- [PreserveSig]
- int Write(
- [In, MarshalAs(UnmanagedType.LPArray, SizeParamIndex = 1)] byte[] data,
- uint size,
- IntPtr processedSize);
- /// <summary>
- /// Seek routine
- /// </summary>
- /// <param name="offset">Offset value</param>
- /// <param name="seekOrigin">Seek origin value</param>
- /// <param name="newPosition">New position pointer</param>
- void Seek(
- long offset, SeekOrigin seekOrigin, IntPtr newPosition);
- /// <summary>
- /// Set size routine
- /// </summary>
- /// <param name="newSize">New size value</param>
- /// <returns>Zero if Ok</returns>
- [PreserveSig]
- int SetSize(long newSize);
- }
- /// <summary>
- /// 7-zip essential in archive interface
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000600600000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface IInArchive
- {
- /// <summary>
- /// Opens archive for reading.
- /// </summary>
- /// <param name="stream">Archive file stream</param>
- /// <param name="maxCheckStartPosition">Maximum start position for checking</param>
- /// <param name="openArchiveCallback">Callback for opening archive</param>
- /// <returns></returns>
- [PreserveSig]
- int Open(
- IInStream stream,
- [In] ref ulong maxCheckStartPosition,
- [MarshalAs(UnmanagedType.Interface)] IArchiveOpenCallback openArchiveCallback);
- /// <summary>
- /// Closes the archive.
- /// </summary>
- void Close();
- /// <summary>
- /// Gets the number of files in the archive file table .
- /// </summary>
- /// <returns>The number of files in the archive</returns>
- uint GetNumberOfItems();
- /// <summary>
- /// Retrieves specific property data.
- /// </summary>
- /// <param name="index">File index in the archive file table</param>
- /// <param name="propId">Property code</param>
- /// <param name="value">Property variant value</param>
- void GetProperty(
- uint index,
- ItemPropId propId,
- ref PropVariant value); // PropVariant
- /// <summary>
- /// Extracts files from the opened archive.
- /// </summary>
- /// <param name="indexes">indexes of files to be extracted (must be sorted)</param>
- /// <param name="numItems">0xFFFFFFFF means all files</param>
- /// <param name="testMode">testMode != 0 means "test files operation"</param>
- /// <param name="extractCallback">IArchiveExtractCallback for operations handling</param>
- /// <returns>0 if success</returns>
- [PreserveSig]
- int Extract(
- [MarshalAs(UnmanagedType.LPArray, SizeParamIndex = 1)] uint[] indexes,
- uint numItems,
- int testMode,
- [MarshalAs(UnmanagedType.Interface)] IArchiveExtractCallback extractCallback);
- /// <summary>
- /// Gets archive property data
- /// </summary>
- /// <param name="propId">Archive property identificator</param>
- /// <param name="value">Archive property value</param>
- void GetArchiveProperty(
- ItemPropId propId, // PROPID
- ref PropVariant value); // PropVariant
- /// <summary>
- /// Gets the number of properties
- /// </summary>
- /// <returns>The number of properties</returns>
- uint GetNumberOfProperties();
- /// <summary>
- /// Gets property information
- /// </summary>
- /// <param name="index">Item index</param>
- /// <param name="name">Name</param>
- /// <param name="propId">Property identifier</param>
- /// <param name="varType">Variant type</param>
- void GetPropertyInfo(
- uint index,
- [MarshalAs(UnmanagedType.BStr)] out string name,
- out ItemPropId propId, // PROPID
- out ushort varType); //VARTYPE
- /// <summary>
- /// Gets the number of archive properties
- /// </summary>
- /// <returns>The number of archive properties</returns>
- uint GetNumberOfArchiveProperties();
- /// <summary>
- /// Gets the archive property information
- /// </summary>
- /// <param name="index">Item index</param>
- /// <param name="name">Name</param>
- /// <param name="propId">Property identifier</param>
- /// <param name="varType">Variant type</param>
- void GetArchivePropertyInfo(
- uint index,
- [MarshalAs(UnmanagedType.BStr)] out string name,
- out ItemPropId propId, // PROPID
- out ushort varType); //VARTYPE
- }
- /// <summary>
- /// 7-zip essential out archive interface
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000600A00000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface IOutArchive
- {
- /// <summary>
- /// Updates archive items
- /// </summary>
- /// <param name="outStream">The ISequentialOutStream pointer for writing the archive data</param>
- /// <param name="numItems">Number of archive items</param>
- /// <param name="updateCallback">The IArchiveUpdateCallback pointer</param>
- /// <returns>Zero if Ok</returns>
- [PreserveSig]
- int UpdateItems(
- [MarshalAs(UnmanagedType.Interface)] ISequentialOutStream outStream,
- uint numItems,
- [MarshalAs(UnmanagedType.Interface)] IArchiveUpdateCallback updateCallback);
- /// <summary>
- /// Gets file time type(?)
- /// </summary>
- /// <param name="type">Type pointer</param>
- void GetFileTimeType(IntPtr type);
- }
- /// <summary>
- /// 7-zip ISetProperties interface for setting various archive properties
- /// </summary>
- [ComImport]
- [Guid("23170F69-40C1-278A-0000-000600030000")]
- [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- internal interface ISetProperties
- {
- /// <summary>
- /// Sets the archive properties
- /// </summary>
- /// <param name="names">The names of the properties</param>
- /// <param name="values">The values of the properties</param>
- /// <param name="numProperties">The properties count</param>
- /// <returns></returns>
- int SetProperties(IntPtr names, IntPtr values, int numProperties);
- }
- #endif
- }
|