compiling the zip2 crate to wasm with the goal of compiling to luau through wasynth
Find a file
Johan Andersson d51a4fc1d0 Fix file name sanitization for incompatible path separators.
Zip files can contain both / and \ as separators regardless of the OS and as we want to return a sanitized PathBuf that only supports the OS separator on the let's convert incompatible separators to compatible ones.

If one doesn't do this then PathBufs will be returned that can have entire paths in the file name such as "src\\lib.rs" on Linux/Mac, instead of srv / lib.rs as 3 separate components.
2018-06-20 01:31:46 +02:00
examples Improve reading from non-seekable streams 2018-06-16 14:14:34 +02:00
script Test only on stable 2015-05-18 11:31:58 +02:00
src Fix file name sanitization for incompatible path separators. 2018-06-20 01:31:46 +02:00
tests Update DEFAULT_VERSION 2018-05-22 23:36:56 +02:00
.gitignore Inital commit, containing crc32 2014-09-07 11:53:43 +00:00
.travis.yml Control backend choice of flate2 2018-05-19 20:03:23 +03:00
appveyor.yml Control backend choice of flate2 2018-05-19 20:03:23 +03:00
Cargo.toml New point release 0.4.0 2018-05-27 10:34:21 +02:00
LICENSE Added Travis support, README and LICENSE 2014-09-11 10:50:41 +02:00
README.md Update README for new version 2018-05-27 10:36:30 +02:00

zip-rs

Build Status Build status Crates.io version

Documentation

Info

A zip library for rust which supports reading and writing of simple ZIP files.

Supported compression formats:

  • stored (i.e. none)
  • deflate
  • bzip2 (optional, enabled by default)

Currently unsupported zip extensions:

  • Most of ZIP64, although there is some support for archives with more than 65535 files
  • Encryption
  • Multi-disk

We aim to support rust versions 1.20+.

Usage

With all default features:

[dependencies]
zip = "0.4"

Without the default features:

[dependencies]
zip = { version = "0.4", default-features = false }

You can further control the backend of deflate compression method with these features:

  • deflate (enabled by default) uses miniz_oxide
  • deflate-miniz uses miniz
  • deflate-zlib uses zlib

For example:

[dependencies]
zip = { version = "0.4", features = ["deflate-zlib"], default-features = false }

Examples

See the examples directory for:

  • How to write a file to a zip.
  • how to write a directory of files to a zip (using walkdir).
  • How to extract a zip file.
  • How to extract a single file from a zip.