package decompress

  1. Overview
  2. Docs
Implementation of Zlib and GZip in OCaml

Install

Dune Dependency

Authors

Maintainers

Sources

decompress-1.5.3.tbz
sha256=f91e6978beff3fcb61440d32f7c99c99f1e8654b4fb18408741d36035373ac60
sha512=c3f402404f76075e6f692ea36e701134a5d833824d5d1166365c6c81fb18b309270bf288ce4c118ac44fd0366d9b6eea0a6309255678d8e1bd2bbfa7ba843461

doc/decompress.de/De/Def/Ns/index.html

Module Def.NsSource

Sourcetype error = [
  1. | `Invalid_compression_level
  2. | `Unexpected_end_of_output
]

The type for deflation errors.

Sourceval pp_error : Format.formatter -> error -> unit

Pretty-printer for error.

Sourceval compress_bound : int -> int

compress_bound len returns a clue about how many bytes we need to store the result of the deflation of len bytes. It's a pessimistic calculation.

Sourceval deflate : ?level:int -> bigstring -> bigstring -> (int, [> error ]) result

deflate ~level src dst deflates the content of src into dst.

In case of sucess, it returns the bytes writen in an Ok result. In case of failure, it returns the error in an Error result. compress_bound can be used to determine how many bytes the user needs to allocate as the destination buffer when he wants to compress N bytes.

Here is an example of how to compress any inputs:

  val input : bigstring

  let len = De.Def.Ns.compress_bound (De.bigstring_length input) in
  let dst = De.bigstring_create len in
  De.Def.Ns.deflate ~level:4 input dst
OCaml

Innovation. Community. Security.