mirror of
https://github.com/SabreTools/SabreTools.IO.git
synced 2026-05-07 21:14:05 +00:00
This change looks dramatic, but it's just separating out the already-split namespaces into separate top-level folders. In theory, every single one could be built into their own Nuget package. `SabreTools.IO.Meta` builds the normal Nuget package that is used by all other projects and includes all namespaces. `SabreTools.IO` builds to `SabreTools.IO.Common` to avoid overwriting issues on publish.
133 lines
5.8 KiB
C#
133 lines
5.8 KiB
C#
// Zlib.cs
|
|
// ------------------------------------------------------------------
|
|
//
|
|
// Copyright (c) 2009-2011 Dino Chiesa and Microsoft Corporation.
|
|
// All rights reserved.
|
|
//
|
|
// This code module is part of DotNetZip, a zipfile class library.
|
|
//
|
|
// ------------------------------------------------------------------
|
|
//
|
|
// This code is licensed under the Microsoft Public License.
|
|
// See the file License.txt for the license details.
|
|
// More info on: http://dotnetzip.codeplex.com
|
|
//
|
|
// ------------------------------------------------------------------
|
|
//
|
|
// Last Saved: <2011-August-03 19:52:28>
|
|
//
|
|
// ------------------------------------------------------------------
|
|
//
|
|
// This module defines classes for ZLIB compression and
|
|
// decompression. This code is derived from the jzlib implementation of
|
|
// zlib, but significantly modified. The object model is not the same,
|
|
// and many of the behaviors are new or different. Nonetheless, in
|
|
// keeping with the license for jzlib, the copyright to that code is
|
|
// included below.
|
|
//
|
|
// ------------------------------------------------------------------
|
|
//
|
|
// The following notice applies to jzlib:
|
|
//
|
|
// Copyright (c) 2000,2001,2002,2003 ymnk, JCraft,Inc. All rights reserved.
|
|
//
|
|
// Redistribution and use in source and binary forms, with or without
|
|
// modification, are permitted provided that the following conditions are met:
|
|
//
|
|
// 1. Redistributions of source code must retain the above copyright notice,
|
|
// this list of conditions and the following disclaimer.
|
|
//
|
|
// 2. Redistributions in binary form must reproduce the above copyright
|
|
// notice, this list of conditions and the following disclaimer in
|
|
// the documentation and/or other materials provided with the distribution.
|
|
//
|
|
// 3. The names of the authors may not be used to endorse or promote products
|
|
// derived from this software without specific prior written permission.
|
|
//
|
|
// THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
|
|
// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
// FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL JCRAFT,
|
|
// INC. OR ANY CONTRIBUTORS TO THIS SOFTWARE BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
|
|
// OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
|
|
// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
//
|
|
// -----------------------------------------------------------------------
|
|
//
|
|
// jzlib is based on zlib-1.1.3.
|
|
//
|
|
// The following notice applies to zlib:
|
|
//
|
|
// -----------------------------------------------------------------------
|
|
//
|
|
// Copyright (C) 1995-2004 Jean-loup Gailly and Mark Adler
|
|
//
|
|
// The ZLIB software is provided 'as-is', without any express or implied
|
|
// warranty. In no event will the authors be held liable for any damages
|
|
// arising from the use of this software.
|
|
//
|
|
// Permission is granted to anyone to use this software for any purpose,
|
|
// including commercial applications, and to alter it and redistribute it
|
|
// freely, subject to the following restrictions:
|
|
//
|
|
// 1. The origin of this software must not be misrepresented; you must not
|
|
// claim that you wrote the original software. If you use this software
|
|
// in a product, an acknowledgment in the product documentation would be
|
|
// appreciated but is not required.
|
|
// 2. Altered source versions must be plainly marked as such, and must not be
|
|
// misrepresented as being the original software.
|
|
// 3. This notice may not be removed or altered from any source distribution.
|
|
//
|
|
// Jean-loup Gailly jloup@gzip.org
|
|
// Mark Adler madler@alumni.caltech.edu
|
|
//
|
|
// -----------------------------------------------------------------------
|
|
|
|
namespace SabreTools.IO.Compression.Deflate
|
|
{
|
|
/// <summary>
|
|
/// Describes how to flush the current deflate operation.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// The different FlushType values are useful when using a Deflate in a streaming application.
|
|
/// </remarks>
|
|
public enum FlushType
|
|
{
|
|
/// <summary>No flush at all.</summary>
|
|
None = 0,
|
|
|
|
/// <summary>Closes the current block, but doesn't flush it to
|
|
/// the output. Used internally only in hypothetical
|
|
/// scenarios. This was supposed to be removed by Zlib, but it is
|
|
/// still in use in some edge cases.
|
|
/// </summary>
|
|
Partial,
|
|
|
|
/// <summary>
|
|
/// Use this during compression to specify that all pending output should be
|
|
/// flushed to the output buffer and the output should be aligned on a byte
|
|
/// boundary. You might use this in a streaming communication scenario, so that
|
|
/// the decompressor can get all input data available so far. When using this
|
|
/// with a ZlibCodec, <c>AvailableBytesIn</c> will be zero after the call if
|
|
/// enough output space has been provided before the call. Flushing will
|
|
/// degrade compression and so it should be used only when necessary.
|
|
/// </summary>
|
|
Sync,
|
|
|
|
/// <summary>
|
|
/// Use this during compression to specify that all output should be flushed, as
|
|
/// with <c>FlushType.Sync</c>, but also, the compression state should be reset
|
|
/// so that decompression can restart from this point if previous compressed
|
|
/// data has been damaged or if random access is desired. Using
|
|
/// <c>FlushType.Full</c> too often can significantly degrade the compression.
|
|
/// </summary>
|
|
Full,
|
|
|
|
/// <summary>Signals the end of the compression/decompression stream.</summary>
|
|
Finish,
|
|
}
|
|
}
|