No Description

Pierre Curto e876bbd321 Merge pull request #72 from cyriltovena/fix-reset 4 years ago
cmd 9085dacd1e Writer: added concurrency support. Fixes #55 4 years ago
fuzz 6c101005f8 Updated fuzz corpus 2. 5 years ago
internal dc54fa4a12 cmd/lz4c: moved commands to local dir 5 years ago
testdata 3953b06bcb DecodeBlock: handle case in shortcut2 where the destination buffer is shorter than 18 bytes. Fixes #51. 5 years ago
.gitignore 817fdcf4cb updated gitignore 5 years ago
.travis.yml d85e8a3d70 updated Travis CI 5 years ago
LICENSE 88478b2614 Added LICENSE 9 years ago
README.md 0554902aa7 lz4.Reader: implement io.Seeker. PR #54. Thanks @ianwilkes. 5 years ago
bench_test.go 2df7315854 Make the hashTable argument to CompressBlock optional 4 years ago
block.go 65e4285c56 fixed invalid goto in CompressBlock 4 years ago
block_test.go a207029655 Rework fast matching 5 years ago
debug.go ea731401f5 perf improvements: removed default unused debug args evaluations; faster writer for short writes 6 years ago
debug_stub.go ea731401f5 perf improvements: removed default unused debug args evaluations; faster writer for short writes 6 years ago
decode_amd64.go 9a39efadad implement block decode in assembly 5 years ago
decode_amd64.s 7590f738d0 implement copy shortcut from c 5 years ago
decode_other.go 21241797f8 lz4.Writer: allocate only if buffer too small. Fixes #52. 5 years ago
decode_test.go 9a39efadad implement block decode in assembly 5 years ago
errors.go aa78dadf73 implement io.Seeker 5 years ago
example_test.go 8c1c303835 Updated README and example. 5 years ago
lz4.go bbd769d4f7 Typo in comment 4 years ago
lz4_go1.10.go 67e4b7ec63 lz4: guard Go-1.10 specific API behind build tags 6 years ago
lz4_notgo1.10.go 67e4b7ec63 lz4: guard Go-1.10 specific API behind build tags 6 years ago
reader.go 76905933af Rewritten block size constants with a formula. 5 years ago
reader_test.go aa78dadf73 implement io.Seeker 5 years ago
writer.go f5d4b63b7a Reset hashtable during Writer reset to ensure deterministic output. 4 years ago
writer_test.go 08cb7fb602 Fixes #71. 4 years ago

README.md

lz4 : LZ4 compression in pure Go

GoDoc Build Status 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

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

go install github.com/pierrec/lz4/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.