Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/gen2brain/go-unarr

Go bindings for unarr (decompression library for RAR, TAR, ZIP and 7z archives)
https://github.com/gen2brain/go-unarr

7z-archives 7zip decompression-library golang golang-library rar rar-format tar

Last synced: about 3 hours ago
JSON representation

Go bindings for unarr (decompression library for RAR, TAR, ZIP and 7z archives)

Awesome Lists containing this project

README

        

# go-unarr

[![Build Status](https://github.com/gen2brain/go-unarr/actions/workflows/test.yml/badge.svg)](https://github.com/gen2brain/go-unarr/actions)
[![GoDoc](https://godoc.org/github.com/gen2brain/go-unarr?status.svg)](https://godoc.org/github.com/gen2brain/go-unarr)
[![Go Report Card](https://goreportcard.com/badge/github.com/gen2brain/go-unarr?branch=master)](https://goreportcard.com/report/github.com/gen2brain/go-unarr)

> Golang bindings for the [unarr](https://github.com/selmf/unarr) library from sumatrapdf.

`unarr` is a decompression library and CLI for RAR, TAR, ZIP and 7z archives.

## GoDoc

See

## Build tags

* `extlib` - use external libunarr library
* `pkgconfig` - enable pkg-config (used with `extlib`)
* `static` - use static library (used with `pkgconfig`)

## Install CLI

```bash
go install github.com/gen2brain/go-unarr/cmd/unarr@latest
```

#### Example

```bash
unarr ./example.7z ./example/
```

#### Build

For one-off builds:

```bash
go build -o ./unarr ./cmd/unarr/*.go
```

For multi-platform cross-compile builds:

```bash
goreleaser --snapshot --skip-publish --rm-dist
```

## Library Examples

#### Install Library

```bash
go get -v github.com/gen2brain/go-unarr
```

#### Open archive

```go
a, err := unarr.NewArchive("test.7z")
if err != nil {
panic(err)
}
defer a.Close()
```

#### Read first entry from archive

```go
err := a.Entry()
if err != nil {
panic(err)
}

data, err := a.ReadAll()
if err != nil {
panic(err)
}
```

#### List contents of archive

```go
list, err := a.List()
if err != nil {
panic(err)
}
```

#### Read known filename from archive

```go
err := a.EntryFor("filename.txt")
if err != nil {
panic(err)
}

data, err := a.ReadAll()
if err != nil {
panic(err)
}
```

#### Read first 8 bytes of the entry

```go
err := a.Entry()
if err != nil {
panic(err)
}

data := make([]byte, 8)

n, err := a.Read(data)
if err != nil {
panic(err)
}
```

#### Read all entries from archive

```go
for {
err := a.Entry()
if err != nil {
if err == io.EOF {
break
} else {
panic(err)
}
}

data, err := a.ReadAll()
if err != nil {
panic(err)
}
}
```

#### Extract contents of archive to destination path

```go
_, err := a.Extract("/tmp/path")
if err != nil {
panic(err)
}
```