compiling the zip2 crate to wasm with the goal of compiling to luau through wasynth
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. |
||
---|---|---|
examples | ||
script | ||
src | ||
tests | ||
.gitignore | ||
.travis.yml | ||
appveyor.yml | ||
Cargo.toml | ||
LICENSE | ||
README.md |
zip-rs
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_oxidedeflate-miniz
uses minizdeflate-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.