# divingbells
[data:image/s3,"s3://crabby-images/b44e2/b44e285e3c1164c3a474f7bdcfa330ec06085fab" alt="build"](https://gitlab.com/erlang-dev/divingBells/-/pipelines)
[data:image/s3,"s3://crabby-images/77e36/77e367443ab207dd3e285a652a7171349e217231" alt="codecov"](https://codecov.io/gl/erlang-dev/divingBells)
[data:image/s3,"s3://crabby-images/e2aba/e2aba350d85a5f091c6e1e97e1c3f36370e6fb54" alt="Release"](https://gitlab.com/erlang-dev/divingBells/-/releases)
[data:image/s3,"s3://crabby-images/944c7/944c767a8525c62487760e469b374dc3ce938ce9" alt="License"](https://www.apache.org/licenses/LICENSE-2.0)
[data:image/s3,"s3://crabby-images/5a275/5a2759a70dc833b912e43bf77ac2003470311e8e" alt="Documentation"](https://hexdocs.pm/divingBells/index.html)
`divingbells` is a escript for compressing and decompressing single file, files (WIP), and directories (WIP)
by using huffman coding or huffman coding-like algorithm.
## Installation
### Rebar3
`divingbells` is built using [rebar3](https://rebar3.readme.io/docs/getting-started),
if this library is used with rebar3 simply put it in your rebar.config file:
```
{deps, [
divingbells
]}.
```
### Other
If you don't use rebar3 it's possibly to get the latest version from [gitlab](https://gitlab.com/erlang-dev/divingBells/-/releases)
## Build
```
$ rebar3 compile
$ rebar3 escriptize
```
The escript is generated at `<project-root>/_build/default/bin/divingbells`.
Copy the executable `divingbells` and put it in your `PATH` in order to use it.
## Test
To run the tests call eunit via rebar3
```
$ rebar3 eunit
```
## Usage
### Configuration
The escript is primarly intended to be used through CLI.
The following configurations can be used
```
-C, --compress compress FILE
-D, --decompress decompress FILE
-f, --file FILE to compress or decomress
-d, --destination-file file to write the result to
-h, --help print this help
```
### Example
```
$ ls
divingbells example.txt
$ ./divingbells -C -f example.txt
$ ls
divingbells example.txt example.txt.dbc
$ ./divingbells -D -f example.txt.dbc -d example.text
$ ls
divingbells example.text example.txt example.txt.dbc
$ cat example.text
hello world
```