CHANGELOG.md

## erlang-rocksdb 2.5.0, released on 2026/01/07

### New Features

- add posting list V2 format with roaring64 bitmaps for fast set operations:
  - New binary format: version byte + serialized roaring bitmap + sorted keys
  - Keys automatically stored in lexicographic (binary memcmp) order
  - Automatic V1 to V2 migration on first merge operation
  - Binary API functions:
    - `posting_list_version/1`: get format version (1 or 2)
    - `posting_list_intersection/2`: AND two posting lists
    - `posting_list_union/2`: OR two posting lists
    - `posting_list_difference/2`: subtract posting lists (A - B)
    - `posting_list_intersection_count/2`: fast cardinality via bitmap
    - `posting_list_bitmap_contains/2`: fast hash-based existence check
    - `posting_list_intersect_all/1`: intersect multiple posting lists
  - CRoaring library integration for efficient bitmap operations

- add postings resource API for fast repeated lookups (Lucene-style naming):
  - Parse once, lookup many times with ~0.1 us/lookup performance
  - `postings_open/1`: parse binary into resource
  - `postings_contains/2`: O(log n) exact lookup
  - `postings_bitmap_contains/2`: O(1) hash lookup
  - `postings_count/1`: get key count
  - `postings_keys/1`: get sorted keys
  - `postings_intersection/2`: AND (accepts binary or resource)
  - `postings_union/2`: OR (accepts binary or resource)
  - `postings_difference/2`: A - B (accepts binary or resource)
  - `postings_intersection_count/2`: fast cardinality
  - `postings_intersect_all/1`: multi-way AND
  - `postings_to_binary/1`: convert resource back to binary

- add enhanced TTL support with column family operations (PR #7, thanks @nyo16):
  - `open_with_ttl_cf/4`: open database with multiple column families, each with its own TTL
  - `get_ttl/2`: get current TTL for a column family
  - `set_ttl/2`: set default TTL for the database
  - `set_ttl/3`: set TTL for a specific column family
  - `create_column_family_with_ttl/4`: create a new column family with a specific TTL
  - See `guides/ttl.md` for documentation

### Bug Fixes

- fix CRoaring bswap64 build error on FreeBSD: use `<sys/endian.h>` instead of `<byteswap.h>`
- fix compaction filter for `value_empty` and `always_delete` rules:
  - Use FilterV2 API instead of Filter for direct Decision control
  - Fix 1-tuple rule parsing using strcmp
  - Use `enif_is_identical()` for atom comparison

### Improvements

- posting list keys are now returned in sorted order (lexicographic)
- set operations use roaring bitmap for O(1) existence checks

## erlang-rocksdb 2.4.1, released on 2026/01/04

### Bug Fixes

- fix posting list merge operator not recognizing operands in `batch_merge`:
  - Fixed atom comparison in `ParseOperand` to use `enif_is_identical()` instead of direct `==` comparison
  - Atoms decoded via `enif_binary_to_term` require proper NIF comparison functions
  - Added `posting_list_batch_merge_test` to verify batch operations work correctly

## erlang-rocksdb 2.4.0, released on 2026/01/04

### New Features

- add posting list merge operator for inverted indexes and tagging systems:
  - New merge operator: `posting_list_merge_operator`
  - Merge operations: `{posting_add, Key}` and `{posting_delete, Key}`
  - Tombstones automatically cleaned during merge operations (no compaction filter needed)
  - Binary format: `<<KeyLength:32/big, Flag:8, KeyData:KeyLength/binary>>` - simple, fast to parse
  - Helper functions (pure Erlang):
    - `posting_list_decode/1`: decode binary to list of entries
    - `posting_list_fold/3`: fold over all entries
  - Helper functions (NIF for efficiency):
    - `posting_list_keys/1`: get active keys only (deduped, tombstones filtered)
    - `posting_list_contains/2`: check if key is active
    - `posting_list_find/2`: find key with tombstone status
    - `posting_list_count/1`: count active keys
    - `posting_list_to_map/1`: get full state as map
  - See `guides/posting_lists.md` for documentation

- add Erlang compaction filter support with two modes:
  - **Declarative rules mode** (fast C++ execution):
    - `{key_prefix, Binary}`: delete keys with matching prefix
    - `{key_suffix, Binary}`: delete keys with matching suffix
    - `{key_contains, Binary}`: delete keys containing pattern
    - `{value_empty}`: delete keys with empty values
    - `{value_prefix, Binary}`: delete keys with matching value prefix
    - `{ttl_from_key, Offset, Length, TTLSeconds}`: delete expired keys based on timestamp in key
    - `{always_delete}`: delete all keys (use with caution)
  - **Erlang callback mode** (flexible):
    - Register an Erlang process as compaction filter handler
    - Handler receives `{compaction_filter, BatchRef, Keys}` messages
    - Reply with `rocksdb:compaction_filter_reply(BatchRef, Decisions)`
    - Supports `keep`, `remove`, and `{change_value, NewBinary}` decisions
    - Configurable batch_size and timeout with safe fallback behavior
- add `bottommost_level_compaction` option to `compact_range/4,5`:
  - `skip`: skip bottommost level compaction
  - `if_have_compaction_filter`: compact bottommost only if filter is configured
  - `force`: force compaction filter to run on all data
  - `force_optimized`: force with optimizations

### Example Usage

```erlang
%% Posting list for inverted index
{ok, Db} = rocksdb:open("mydb", [
    {create_if_missing, true},
    {merge_operator, posting_list_merge_operator}
]).

%% Add keys to posting list
ok = rocksdb:merge(Db, <<"term:erlang">>, {posting_add, <<"doc1">>}, []),
ok = rocksdb:merge(Db, <<"term:erlang">>, {posting_add, <<"doc2">>}, []).

%% Delete a key (adds tombstone, cleaned on next read)
ok = rocksdb:merge(Db, <<"term:erlang">>, {posting_delete, <<"doc1">>}, []).

%% Read and process - tombstones automatically removed
{ok, Binary} = rocksdb:get(Db, <<"term:erlang">>, []),
Keys = rocksdb:posting_list_keys(Binary).   %% [<<"doc2">>]
```

```erlang
%% Declarative rules mode - delete temporary and expired keys
{ok, Db} = rocksdb:open("mydb", [
    {create_if_missing, true},
    {compaction_filter, #{
        rules => [
            {key_prefix, <<"tmp_">>},
            {key_suffix, <<"_expired">>},
            {ttl_from_key, 0, 8, 3600}  % 1 hour TTL from key bytes
        ]
    }}
]).

%% Erlang callback mode - custom filter logic
%% Handler must be a PID of a running process
HandlerPid = spawn(fun filter_loop/0),
{ok, Db} = rocksdb:open("mydb", [
    {compaction_filter, #{
        handler => HandlerPid,  % PID of the handler process
        batch_size => 100,
        timeout => 5000
    }}
]).

%% Force compaction filter to run on all data
ok = rocksdb:compact_range(Db, undefined, undefined, [
    {bottommost_level_compaction, force}
]).
```

### Bug Fixes

- fix compaction filter resource lifetime bug: keep native reference until callback completes
  to prevent use-after-free when handler times out or dies
- fix FreeBSD build: add system include path for malloc_np.h in RocksDB build
- replace std::atomic with mutex-protected bool for better portability

### Improvements

- FreeBSD CI now uses erlang-runtime28 with LLVM 18 for full C++20 support

## erlang-rocksdb 2.3.0, released on 2026/01/03

### New Features

- add SST file support:
  - SST File Writer: `sst_file_writer_open/2,3`, `sst_file_writer_put/3`, `sst_file_writer_merge/3`, `sst_file_writer_delete/2`, `sst_file_writer_delete_range/3`, `sst_file_writer_finish/1,2`
  - Ingest External File: `ingest_external_file/3,4` for loading SST files into database
  - SST File Reader: `sst_file_reader_open/2`, `sst_file_reader_iterator/2`, `sst_file_reader_table_properties/1`, `sst_file_reader_verify_checksum/1`
  - Merge operator support in SST files (counter, erlang, bitset)
- add `sst_file_manager_tracked_files/1` API to get files tracked by SST File Manager
- add transaction batch get operations:
  - Optimistic transactions: `transaction_get_for_update/3,4`, `transaction_multi_get/3,4`, `transaction_multi_get_for_update/3,4`
  - Pessimistic transactions: `pessimistic_transaction_multi_get/3,4`, `pessimistic_transaction_multi_get_for_update/3,4`
- add new read options:
  - `readahead_size`: configure readahead buffer size for sequential reads
  - `async_io`: enable asynchronous I/O for iterators

### Bug Fixes

- fix memory leak in CoalescingIterator error paths
- fix memory leak in TransactionIterator error paths
- fix memory leak in PessimisticTransactionIterator error paths
- add null check for enif_alloc_env in NewBatch

### Improvements

- add FreeBSD CI testing using vmactions/freebsd-vm

### Documentation

- add SST files guide
- update backup guide with correct function names and additional functions
- improve transactions documentation
- add multi_get to getting started guide
- fix documentation links and typos

## erlang-rocksdb 2.2.0, released on 2025/12/30

### New Features

- add `multi_get/2,3,4` API for efficient batch key retrieval
- add extended statistics support with 45+ tickers and 13+ histograms:
  - Block cache statistics: `block_cache_miss`, `block_cache_hit`, `block_cache_bytes_read/write`
  - Read/write operation statistics: `bytes_written/read`, `number_keys_written/read/updated`
  - Compaction statistics: `compact_read/write_bytes`, `num_files_in_single_compaction`
  - Memtable statistics: `memtable_hit/miss`, `write_done_by_self/other`, `wal_synced`
  - Transaction statistics: `txn_overhead_mutex`, `txn_duplicate_key_overhead`
  - Core operation histograms: `db_get`, `db_write`, `db_seek`, `flush_time`, `compaction_time`
  - I/O histograms: `sst_read/write_micros`, `wal_file_sync_micros`, `bytes_per_read/write`
  - Transaction histograms: `num_commit/filter_per_transaction`
- add BlobDB enhancements:
  - `get_blob_statistics/1,2`: BlobDB tickers (blob_bytes_read/written, blob_gc_*)
  - `get_blob_histogram/2,3`: BlobDB histograms (blob_db_get/put/seek_micros)
  - `get_blob_cache_properties/1`: blob cache usage and capacity
  - `allow_unprepared_value` iterator option for lazy blob loading
  - `iterator_prepare_value/1` for explicit blob value loading
  - `get_column_family_metadata/1,2` with blob file information

### Bug Fixes

- fix memory leak in `parse_iterator_options` on error paths
- fix null pointer dereference in `Iterators()` for invalid column family handles
- fix null check for `enif_alloc` in `NewBatch()` preventing crash on OOM
- fix double-free in `Iterators()` when using shared bound slices
- fix exception handling in `Iterators()` to return proper error tuple
- fix typo PREPOLUATE -> PREPOPULATE in blob cache atom

### Documentation

- add statistics guide
- add multi_get usage to getting started guide

## erlang-rocksdb 2.1.0, released on 2025/12/28

- add Pessimistic Transaction support for high-contention workloads:
  - `open_pessimistic_transaction_db/2,3`: open a TransactionDB with row-level locking
  - `pessimistic_transaction/2,3`: begin a new transaction
  - `pessimistic_transaction_put/3,4`: put with lock acquisition
  - `pessimistic_transaction_get/3,4`: read without lock
  - `pessimistic_transaction_get_for_update/3,4`: read with exclusive lock
  - `pessimistic_transaction_delete/2,3`: delete with lock
  - `pessimistic_transaction_iterator/2,3`: create transaction iterator
  - `pessimistic_transaction_commit/1`: commit transaction
  - `pessimistic_transaction_rollback/1`: rollback transaction
  - `release_pessimistic_transaction/1`: release resources
- add Pessimistic Transaction savepoint support:
  - `pessimistic_transaction_set_savepoint/1`: mark a savepoint
  - `pessimistic_transaction_rollback_to_savepoint/1`: rollback to last savepoint
  - `pessimistic_transaction_pop_savepoint/1`: discard savepoint without rollback
- add Pessimistic Transaction introspection:
  - `pessimistic_transaction_get_id/1`: get unique transaction ID
  - `pessimistic_transaction_get_waiting_txns/1`: get lock contention info
- TransactionDB options: lock_timeout, deadlock_detect, max_num_locks, num_stripes
- Transaction options: set_snapshot, deadlock_detect, lock_timeout
- all pessimistic transaction operations use dirty NIFs to prevent blocking the Erlang scheduler

## erlang-rocksdb 2.0.0, released on 2025/12/28

- bump to rocksdb version [10.7.5](https://github.com/facebook/rocksdb/releases/tag/v10.7.5)
- add Wide-Column Entity API for structured data storage:
  - `put_entity/4,5`: store key with multiple named columns
  - `get_entity/3,4`: retrieve entity columns as proplist
  - `iterator_columns/1`: get columns from current iterator position
  - `delete_entity/3,4`: convenience wrapper for delete
- add `coalescing_iterator/3` for efficient multi-column-family iteration
- add `auto_readahead_size` iterator option for automatic prefetch tuning
- add `auto_refresh_iterator_with_snapshot` iterator option
- fix CMake 3.31 compatibility
- fix bundled snappy linking on Linux (RTTI mismatch)
- fix compiler warnings

## erlang-rocksdb 1.9.0, released on 2025/02/01

- bump to rocksdb version [9.10.0]((https://github.com/facebook/rocksdb/releases/tag/v9.10.0)
- bump to snappy 1.2.1
- fix write_options
- fix memory leak
- handle manual_wal_flush option


## erlang-rocksdb 1.8.0, released on 2022/11/04

- bring compatibility with with Apple Mac M1 and Erlang OTP 25 
- bump to rocksdb version [7.7.3]((https://github.com/facebook/rocksdb/releases/tag/v7.7.3)
- add support for BLOB databases
- add `rocksdb:transaction_rollback/1` function
- add `rocksdb:release_transaction/1` function
- fix: bind transactions OPs that require it to IO threads.
- fix transaction iterator
- fix transaction leaks: ensure the resource is always closed
- fix specs

** BREAKING CHANGES **

- rocksdb:transction_commit doesn't delete the transaction
- `rocksdb_transaction:iterators`: database handle is removed from the functions parameter. Instead only use the
transaction resource.


## erlang-rocksdb 1.7.0, released on 2021/11/03

- bring compatibility with with Apple Mac M1 and Erlang OTP 24
- bump to rocksdb version [6.25.3]((https://github.com/facebook/rocksdb/releases/tag/v6.25.3)
- add `rocksdb:open_readonly/3` function to open databases in read only mode (useful for concurrency)
- add support for read options `read_tier`
- add support for direct IO  options `use_direct_reads` & `use_direct_io_for_flush_and_compaction`
- new staistics API, exposing `rocksdb::Statistics` object.
- fix list merge operaion when empty
- add `unordered_write` and & `two_write_queues` open options
- fix `transaction_get`  when Options is unset.
- fix iterator behaviour

### REAKING CHANGES

- return an invalid iterator if the user try to use next or prev without
having set the initial location of the iterator:
  - calling next, and prev without having put the iterator at a specific
  key or location (first, last) will now return the tuple `{error, invalid_iterator}`
  - fix crash when moving to next key on a new iterator.
  - fix behavior of Refresh. Refresh is supposed to reset completely the
  state of the iterator. Fix test accordingly.

- `transction_get/2` has been removed, and is replaced by `transction_get/3` with the third argument to spass the options.
- `transaction_get/3` to get using a column family is now `transaction_get/4`



## erlang-rocksdb 1.6.0, released on 2020/10/16

- bump to rocksdb version [6.13.3](https://github.com/facebook/rocksdb/releases/tag/v6.13.3)
- improve compression support: add comprssion_opts and bottomost_compression support
- fix memory leaks: RateLimiter, Snapshots, BitsetMergeOperator, Iterators, WriteBinaryUpdayte
- fix build for OTP 23

## erlang-rocksdb 1.5.1, released on 2020/02/09

- fix memory leaks in erocksdb::WriteBinaryUpdate, erokcsdb::CompactRange & erocksdb::Repair
- fix: use code:lib_dir/1 to find correct ei dir

## erlang-rocksdb 1.5.0, released on 2020/01/21

- Fix lz4 and snappy lib install dir to work on systems using lib64
- Add `atomic_flush` db option
- bump rocksdb to version [6.5.2](https://github.com/facebook/rocksdb/releases/tag/v6.5.2)

## erlang-rocksdb 1.4.0, released on 2019/11/04

- fix build on OpenBSD
- bump rocksdb to version [6.4.6](https://github.com/facebook/rocksdb/releases/tag/v6.4.6)


## erlang-rocksdb 1.3.2, released on 2019/09/13

- fix build using installed rocksdb on the system

## erlang-rocksdb 1.3.1, released on 2019/08/28

- fix cache_info segfault

## erlang-rocksdb 1.3.0, released on 2019/08/26

- bump rocksdb to version [6.2.2](https://github.com/facebook/rocksdb/releases/tag/v6.2.2)
- new: support of the windows platform (build using MSVC)
- fix: transaction log iterator

## erlang-rocksdb 1.2.0, released on 2019/06/11

- bump rocksdb to version [6.1.2](https://github.com/facebook/rocksdb/releases/tag/v6.1.2)
- use C++11 atomics to replace pthreads and GCC specific threading and atomics
- fix: parralelism build options
- fix: miscellaneous dialyze and C warnings

## erlang-rocksdb 1.1.1, released on 2019/04/12

- fix spec

erlang-rocksdb 1.1.0, released on 2019/03/26

- bump rocksdb to version [5.18.3](https://github.com/facebook/rocksdb/releases/tag/v5.18.3)
- add preliminary support for optimistic transactions
- make build more parallel when cores are available
- fix iterate_upper_bound type.

## erlang-rocksdb 1.0.0, released on 2019/01/31


- first stable version
- miscellaneous build improvements with [new build options and optimisations](https://gitlab.com/barrel-db/erlang-rocksdb/blob/master/doc/customize_rocksdb_build.md)
- stable API (refactored in #87, #88)

## erlang-rocksdb 0.26.2, released on 2019/01/24

- fix `batch_merge/3` to call the right function

## erlang-rocksdb 0.26.1, released on 2018/12/11

- fix build on freebsd
- support build with the Thread Building Blocks library (TBB)

## erlang-rocksdb 0.26.0, released on 2018/12/05

- allows [customized builds](http://gitlab.com/barrel-db/erlang-rocksdb/blob/master/doc/customize_rocksdb_build.md)
- fix compilations warnings

### BREAKING CHANGES

- build is now using cmake instead of autotools
- corruption errors return `{error, {corruption, Reaason :: string()}}` inst#ead of `corruption`.

## erlang-rocksdb 0.25.0, released on 2018/11/21

- bump to rocksdb 0.17.2
- bump snappy to 1.1.7
- bump lz4  to 1.8.3
- add `rocksdb:open_with_ttl/2`.
- add `no_slowdown` and `low_pri` write options
- add `manual_wal_flush`  db option
- add support for WriteBuffer (#64)
- add `sst_file_manger()` resource to provide SSTFileManager support and manage disk space. (#74)
- fix `aproximate_sizes_test` and `approximate_memtable_stats_test`

### BREAKING CHANGES

- handle flush options in rocksdb:flush/{2, 3}
  With this change `rocksdb:flush/1` has been removed while second parameter
  of `rocksdb:flush/2` are now `FlushOptions::flush_options()`.
  Use `rocksdb:flush/3` to flush a column family
- change signature of `rocksdb:get_approximate_memtable_stats/{2,3}`
  to `rocksdb:get_approximate_memtable_stats/4` .


## erlang-rocksdb 0.24.0, released on 2018/11/06

- add `rocksdb:get_approximate_sizes/{3,4}`: amroximate the size of a range of keys
- add `rocksdb:get_approximate_memtable_stats/{2,3}` : aproximate the size and the 
  number of keys in a memtable
- add `rocksdb:compact_range/{4,5}`: Compact the underlying storage for a key


## erlang-rocksdb 0.23.3, released on 2018/10/31

- fix possible memory leaks when trying to open a bad CF resource.


## erlang-rocksdb 0.23.2, released on 2018/10/30

- fix memory leaks


## erlang-rocksdb 0.23.1, released on 2018/10/08

- fix bitset merge operator under load


## erlang-rocksdb 0.23.0, released on 2018/10/05

- add bytewise and reverse bytewise comparators
- add iterate_upper_bound, iterate_lower_bound_options and prefix_same_as_start to iterator options
- improve: prevernt garbage collection in batch
- fix bitset merge operator, handle exceptions
- fix counter merge operator, handle exceptions


## erlang-rocksdb 0.22.0, released on 2018/09/25

- fix NIF memory leak in `erocksdb::Get`
- add counter_merge_operator


## erlang-rocksdb 0.21.0, released on 2018/09/16

- bump to rocksdb 5.15.10
- add: erlang merge operator
- add: erlang bitset merge operator
- add: rocksdb:batch_data_size/1
- add: prefix_transform option


## erlang-rocksdb 0.20.0, released on 2018/08/03

- bump to rocksdb 5.14.2


## erlang-rocksdb 0.19.0, released on 2018/07/04

- bump to rocksdb 5.13.4
- add `rocksdb:set_strict_capacity_limit/2` for cache
- add `optimize_filters_for_hits` database option
- add `new_table_reader_for_compaction_inputs` database option
- add `max_subcompactions` database option


## erlang-rocksdb 0.18.0, released on 2018/05/03

- bump to rocksdb 5.12.4


## erlang-rocksdb 0.17.0, released on 2018/03/25

- bump ro rocksdb 5.11.3
- improve build to make it faster, only use makefiles
- optimise single operations Get/Put/Delete/DeleteSing: don't call batch
- optimise write: use batch and do less operations in the the nif: make scheduler happy
- fix leak in batch
- breaking change: rename `close_batch/1`  in `relase_batch/1`


## erlang-rocksdb 0.16.0, released on 2018/03/13

- add single_delete operation (to key/value and batch api)
- add iterator_refresh function
- add support for level_compaction_dynamic_level_bytes for column family options
- add rate_limiter support
- many optimisations to the source code and build
- bump to rocksdb 5.10.4


## erlang-rocksdb 0.15.0, released on 2018/02/10

- add support for lz4 compression
- add new database option `max_background_jobs`
- fix: potential memory leak


## erlang-rocksdb 0.14.0, released on 2018/01/31

- bump to rocksdb 5.7.5
- bump to snappy 1.1.4


## erlang-rocksdb 0.13.1, released on 2017/09/07

- fix: remove memory leaks spotted with valgrind

## erlang-rocksdb 0.13.0, released on 2017/09/06

* add new cache api

	-  new_lru_cache/1,
	-  new_clock_cache/1,
	-  get_usage/1,
	-  get_pinned_usage/1,
	-  set_capacity/2,
	-  get_capacity/1
	-  release_cache/1

* add new env api

	- default_env/0,
	- mem_env/0,
	- set_env_background_threads/{2, 3},
	- destroy_env/1

* remove default shared block cache in private env to reduce the vm memory usage.


## erlang-rocksdb 0.12.0, released on 2017/09/05

- add get_block_cache_usage/1
- add block_cache_capacity/{1, 0}
- add new db option {env, Env} where Env can be `default` or `memenv`.
- add new db option {db_write_buffer_size, INT}
- fix: cache usahe, correctly reuse the cache among instances
- fix: options parsing, reuse code where we can and correctly
handle db optinos

### BREAKING CHANGE

The following cache functions has been removed:

-  new_lru_cache/1,
-  new_clock_cache/1,
-  get_usage/1,
-  get_pinned_usage/1,
-  set_capacity/2,
-  get_capacity/1

instead use the new block_cache function to change the
size of the shared cache. A new api to setup different caches
will come in the next version.

The following functions has been removed:

- default_env/0,
- mem_env/0,
- set_background_threads/2, set_background_threads/3,
- destroy_env/1]).

For now it's not possible to create a shared environment. also
the {in_memory, true} setting has been removed.

To set a memory environement use the option {env, memenv}.


## erlang-rocksdb 0.11.0, released on 2017/07/29

- add rocksdb:get_snapshot_sequence/1


## erlang-rocksdb 0.10.0, released on 2017/07/28

- bump to rocksdb 5.7.2
- add: rocksdb:delete_range/{4,5}
- add: support for the backup api
- add: rocksdb:destroy_column_family/1
- proper fix to handle an iterator with column family issue


## erlang-rocksdb 0.9.1, released on 2017/07/26

- fix iterator with column familly issue
- fix mutex usage igit push --tagsn the db object


## erlang-rocksdb 0.9.0, released on 2017/05/31

- bump to rocksdb 5.4.5
- remove `disable_data_sync` db option, optimisations removed in rocksdb
- remove `timeout_hint_us` db option, was useless since 2 years
- remove `verify_checksums_in_compaction` db option. it's always done.
- remove `skip_table_builder_flush` db option
- remove `allow_os_buffer` db option
- add `{seek_for_prev, Prev}` db option
- allows to fold a column familly


## erlang-rocksdb 0.8.2, released on 2017/05/17

- fix: fix default_env/0 & mem_env/0 spec


## erlang-rocksdb 0.8.1, released on 2017/05/17

- fix: use an uint64 to set the capacity of LRU or CLOCK caches.


## erlang-rocksdb 0.8.0, released on 2017/05/17

- replace custom pool by dirty-nif calls
- allows a cache to be shared between databases (option `block_cache` from the block options)
- allows an environment to be set and shared across databases (option `env`)
- add support of batch operations, allows you to incrementatly update it in memory
- add support for transaction log operations (iteration and replication)