1
0
Fork 0
mirror of https://codeberg.org/forgejo/forgejo.git synced 2024-12-31 14:14:07 -05:00
forgejo/vendor/github.com/pierrec/lz4/v4
2021-02-28 18:08:33 -05:00
..
internal go1.16 (#14783) 2021-02-28 18:08:33 -05:00
.gitignore go1.16 (#14783) 2021-02-28 18:08:33 -05:00
go.mod Vendor Update Go Libs (#13444) 2020-11-06 13:41:42 -05:00
go.sum go1.16 (#14783) 2021-02-28 18:08:33 -05:00
LICENSE Vendor Update Go Libs (#13444) 2020-11-06 13:41:42 -05:00
lz4.go Vendor Update Go Libs (#13444) 2020-11-06 13:41:42 -05:00
options.go Vendor Update Go Libs (#13444) 2020-11-06 13:41:42 -05:00
options_gen.go Vendor Update Go Libs (#13444) 2020-11-06 13:41:42 -05:00
reader.go Vendor Update Go Libs (#13444) 2020-11-06 13:41:42 -05:00
README.md go1.16 (#14783) 2021-02-28 18:08:33 -05:00
state.go Vendor Update Go Libs (#13444) 2020-11-06 13:41:42 -05:00
state_gen.go Vendor Update Go Libs (#13444) 2020-11-06 13:41:42 -05:00
writer.go Vendor Update Go Libs (#13444) 2020-11-06 13:41:42 -05:00

lz4 : LZ4 compression in pure Go

Go Reference CI Go Report Card GitHub tag (latest SemVer)

Overview

This package provides a streaming interface to LZ4 data streams as well as low level compress and uncompress functions for LZ4 data blocks. The implementation is based on the reference C one.

Install

Assuming you have the go toolchain installed:

go get github.com/pierrec/lz4/v4

There is a command line interface tool to compress and decompress LZ4 files.

go install github.com/pierrec/lz4/v4/cmd/lz4c

Usage

Usage of lz4c:
  -version
        print the program version

Subcommands:
Compress the given files or from stdin to stdout.
compress [arguments] [<file name> ...]
  -bc
        enable block checksum
  -l int
        compression level (0=fastest)
  -sc
        disable stream checksum
  -size string
        block max size [64K,256K,1M,4M] (default "4M")

Uncompress the given files or from stdin to stdout.
uncompress [arguments] [<file name> ...]

Example

// Compress and uncompress an input string.
s := "hello world"
r := strings.NewReader(s)

// The pipe will uncompress the data from the writer.
pr, pw := io.Pipe()
zw := lz4.NewWriter(pw)
zr := lz4.NewReader(pr)

go func() {
	// Compress the input string.
	_, _ = io.Copy(zw, r)
	_ = zw.Close() // Make sure the writer is closed
	_ = pw.Close() // Terminate the pipe
}()

_, _ = io.Copy(os.Stdout, zr)

// Output:
// hello world

Contributing

Contributions are very welcome for bug fixing, performance improvements...!

  • Open an issue with a proper description
  • Send a pull request with appropriate test case(s)

Contributors

Thanks to all contributors so far!

Special thanks to @Zariel for his asm implementation of the decoder.

Special thanks to @klauspost for his work on optimizing the code.