SimpleCompress 1.1.0

dotnet add package SimpleCompress --version 1.1.0                
NuGet\Install-Package SimpleCompress -Version 1.1.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="SimpleCompress" Version="1.1.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add SimpleCompress --version 1.1.0                
#r "nuget: SimpleCompress, 1.1.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install SimpleCompress as a Cake Addin
#addin nuget:?package=SimpleCompress&version=1.1.0

// Install SimpleCompress as a Cake Tool
#tool nuget:?package=SimpleCompress&version=1.1.0                

SimpleCompress

Multi-file compression with long path support and good compression when source has many duplicate files

The C# version specifically uses only standard GAC dependencies so it can be included in .msi installers.

Important This tool does not keep track of file permissions, flags, creation dates or any other meta-data. It will lose execute flags.

Symlinks are supported for directories. If a link target is outside the archive, it will be dereferenced and expanded to a normal file. If the link target is within the archive, it will be restored as a link.

The npm package can be installed as a library, or as a CLI tool "sz" with npm i -g simple-compress.

Usage:
    sz pack <src directory> <target file> [flags]
    sz unpack <src file> <target directory> [flags]

Flags:
    h : (unpack) replace duplicate files with hard links
    x : (pack) create an expander script for the archive

Internals

Filesystem / IO:

The .Net version uses a cut down version of https://github.com/i-e-b/tinyQuickIO to handle long file paths in Windows. The built in .Net IO namespace often fails with node_modules folders in large projects. Note that long file names are not currently supported for compressed and temp files.

Compression:

It works like a tar-gz: First all files are checked for duplicates (if it has the same name and MD5 it is considered a duplicate). Then a temp file is written that is of the structure <MD5:16 bytes><length:8 bytes><paths:utf8 str><length:8 bytes><data:byte array> repeated for each unique file. Lengths are 64 bit little endian. Paths are UTF-8. Data is as in the source file. This temp file is then compressed to a single gzip stream as the final output (it is not a .zip file) If a signature is added, the final format is <"szX509":6 bytes><sig-length:8 bytes><signature:byte array><gzip-data:byte array>

Decompression:

Reverse of compression -- first the gzip stream is expanded out to a temp file, then the structure is read to get a list of paths. The data is then read to disk at first path in the list, then that result file is copied around to all the other locations. Each file when written can be compared to the archive's MD5 hash and an error displayed if there is any corruption. When a signed file is read, the signature header is read, and optionally checked. The remaining data follows the normal expansion process. If a signature .cer file is provided, the signature must match the data. If not signature file is provided, the check is skipped and the data can be expanded as normal.

Notes on signing

Windows:

Recipients should only ever get the public key (*.cer). Simple compress does no checking against certificate revocation. Never use included demo keys for anything other than running unit tests.

makecert.exe -sv MyKey.pvk -n �CN=MyProjName� MyKey.cer
pvk2pfx.exe -pvk MyKey.pvk -spc MyKey.cer -pfx MyPFX.pfx -po your-password-here
Product Compatible and additional computed target framework versions.
.NET Framework net45 is compatible.  net451 was computed.  net452 was computed.  net46 was computed.  net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.1.0 1,006 5/18/2018
1.0.0 992 5/4/2018

Adding signing and verify support