## erlang-rockksdb 1.9.0, WIP
- 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)