zstd/lib
2016-07-17 20:42:21 +02:00
..
common moved zstd.h to /lib 2016-07-17 20:42:21 +02:00
compress minor compression level corrections 2016-07-17 16:21:37 +02:00
decompress fixed : premature frame end on zero-sized raw block - reported by @ebiggers 2016-07-17 15:39:24 +02:00
dictBuilder minor compression level corrections 2016-07-17 16:21:37 +02:00
legacy Add legacy support for the low-level streaming API 2016-07-17 01:03:26 +02:00
.gitignore Added "dictionary decompression" example 2016-07-07 14:08:00 +02:00
libzstd.pc.in Initial release 2015-01-24 01:58:16 +01:00
LICENSE Initial release 2015-01-24 01:58:16 +01:00
Makefile moved zstd.h to /lib 2016-07-17 20:42:21 +02:00
README.md moved zstd.h to /lib 2016-07-17 20:42:21 +02:00
zstd.h moved zstd.h to /lib 2016-07-17 20:42:21 +02:00

zstd - library files

The lib directory contains several directories. Depending on target use case, it's enough to include only files from relevant directories.

API

Zstandard's stable API is exposed within zstd.h, at the root of lib directory.

Advanced API

Some additional API may be useful if you're looking into advanced features :

  • common/error_public.h : transform function result into an enum, for precise error handling.
  • ZSTD_STATIC_LINKING_ONLY : if you define this macro before including zstd.h, it will give access to advanced and experimental API. These APIs shall never be used with dynamic library ! They are not "stable", their definition may change in the future. Only static linking is allowed.

Modular build

Directory common/ is required in all circumstances. You can select to support compression only, by just adding files from the compress/ directory, In a similar way, you can build a decompressor-only library with the decompress/ directory.

Other optional functionalities provided are :

  • dictBuilder/ : this directory contains source files required to create dictionaries. The API can be consulted in dictBuilder/zdict.h. It also depends on common/ and compress/ .

  • legacy/ : this directory contains source code to decompress previous versions of Zstd, starting from v0.1. The main API can be consulted in legacy/zstd_legacy.h. Note that it's required to compile the library with ZSTD_LEGACY_SUPPORT = 1 . Advanced API from each version can be found in its relevant header file. For example, advanced API for version v0.4 is in zstd_v04.h . It also depends on common/ and decompress/ .

Streaming API

Streaming is currently provided by common/zbuff.h.

Miscellaneous

The other files are not source code. There are :

  • LICENSE : contains the BSD license text
  • Makefile : script to compile or install zstd library (static and dynamic)
  • libzstd.pc.in : for pkg-config (make install)