286 lines
9.6 KiB
C
286 lines
9.6 KiB
C
/* Copyright (c) 2013, Facebook, Inc. All rights reserved.
|
|
This source code is licensed under the BSD-style license found in the
|
|
LICENSE file in the root directory of this source tree. An additional grant
|
|
of patent rights can be found in the PATENTS file in the same directory.
|
|
Copyright (c) 2011 The LevelDB Authors. All rights reserved.
|
|
Use of this source code is governed by a BSD-style license that can be
|
|
found in the LICENSE file. See the AUTHORS file for names of contributors.
|
|
|
|
C bindings for leveldb. May be useful as a stable ABI that can be
|
|
used by programs that keep leveldb in a shared library, or for
|
|
a JNI api.
|
|
|
|
Does not support:
|
|
. getters for the option types
|
|
. custom comparators that implement key shortening
|
|
. capturing post-write-snapshot
|
|
. custom iter, db, env, cache implementations using just the C bindings
|
|
|
|
Some conventions:
|
|
|
|
(1) We expose just opaque struct pointers and functions to clients.
|
|
This allows us to change internal representations without having to
|
|
recompile clients.
|
|
|
|
(2) For simplicity, there is no equivalent to the Slice type. Instead,
|
|
the caller has to pass the pointer and length as separate
|
|
arguments.
|
|
|
|
(3) Errors are represented by a null-terminated c string. NULL
|
|
means no error. All operations that can raise an error are passed
|
|
a "char** errptr" as the last argument. One of the following must
|
|
be true on entry:
|
|
*errptr == NULL
|
|
*errptr points to a malloc()ed null-terminated error message
|
|
On success, a leveldb routine leaves *errptr unchanged.
|
|
On failure, leveldb frees the old value of *errptr and
|
|
set *errptr to a malloc()ed error message.
|
|
|
|
(4) Bools have the type unsigned char (0 == false; rest == true)
|
|
|
|
(5) All of the pointer arguments must be non-NULL.
|
|
*/
|
|
|
|
#ifndef STORAGE_ROCKSDB_INCLUDE_C_H_
|
|
#define STORAGE_ROCKSDB_INCLUDE_C_H_
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <stdarg.h>
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
|
|
/* Exported types */
|
|
|
|
typedef struct rocksdb_t rocksdb_t;
|
|
typedef struct rocksdb_cache_t rocksdb_cache_t;
|
|
typedef struct rocksdb_comparator_t rocksdb_comparator_t;
|
|
typedef struct rocksdb_env_t rocksdb_env_t;
|
|
typedef struct rocksdb_filelock_t rocksdb_filelock_t;
|
|
typedef struct rocksdb_filterpolicy_t rocksdb_filterpolicy_t;
|
|
typedef struct rocksdb_iterator_t rocksdb_iterator_t;
|
|
typedef struct rocksdb_logger_t rocksdb_logger_t;
|
|
typedef struct rocksdb_options_t rocksdb_options_t;
|
|
typedef struct rocksdb_randomfile_t rocksdb_randomfile_t;
|
|
typedef struct rocksdb_readoptions_t rocksdb_readoptions_t;
|
|
typedef struct rocksdb_seqfile_t rocksdb_seqfile_t;
|
|
typedef struct rocksdb_snapshot_t rocksdb_snapshot_t;
|
|
typedef struct rocksdb_writablefile_t rocksdb_writablefile_t;
|
|
typedef struct rocksdb_writebatch_t rocksdb_writebatch_t;
|
|
typedef struct rocksdb_writeoptions_t rocksdb_writeoptions_t;
|
|
|
|
/* DB operations */
|
|
|
|
extern rocksdb_t* rocksdb_open(
|
|
const rocksdb_options_t* options,
|
|
const char* name,
|
|
char** errptr);
|
|
|
|
extern void rocksdb_close(rocksdb_t* db);
|
|
|
|
extern void rocksdb_put(
|
|
rocksdb_t* db,
|
|
const rocksdb_writeoptions_t* options,
|
|
const char* key, size_t keylen,
|
|
const char* val, size_t vallen,
|
|
char** errptr);
|
|
|
|
extern void rocksdb_delete(
|
|
rocksdb_t* db,
|
|
const rocksdb_writeoptions_t* options,
|
|
const char* key, size_t keylen,
|
|
char** errptr);
|
|
|
|
extern void rocksdb_write(
|
|
rocksdb_t* db,
|
|
const rocksdb_writeoptions_t* options,
|
|
rocksdb_writebatch_t* batch,
|
|
char** errptr);
|
|
|
|
/* Returns NULL if not found. A malloc()ed array otherwise.
|
|
Stores the length of the array in *vallen. */
|
|
extern char* rocksdb_get(
|
|
rocksdb_t* db,
|
|
const rocksdb_readoptions_t* options,
|
|
const char* key, size_t keylen,
|
|
size_t* vallen,
|
|
char** errptr);
|
|
|
|
extern rocksdb_iterator_t* rocksdb_create_iterator(
|
|
rocksdb_t* db,
|
|
const rocksdb_readoptions_t* options);
|
|
|
|
extern const rocksdb_snapshot_t* rocksdb_create_snapshot(
|
|
rocksdb_t* db);
|
|
|
|
extern void rocksdb_release_snapshot(
|
|
rocksdb_t* db,
|
|
const rocksdb_snapshot_t* snapshot);
|
|
|
|
/* Returns NULL if property name is unknown.
|
|
Else returns a pointer to a malloc()-ed null-terminated value. */
|
|
extern char* rocksdb_property_value(
|
|
rocksdb_t* db,
|
|
const char* propname);
|
|
|
|
extern void rocksdb_approximate_sizes(
|
|
rocksdb_t* db,
|
|
int num_ranges,
|
|
const char* const* range_start_key, const size_t* range_start_key_len,
|
|
const char* const* range_limit_key, const size_t* range_limit_key_len,
|
|
uint64_t* sizes);
|
|
|
|
extern void rocksdb_compact_range(
|
|
rocksdb_t* db,
|
|
const char* start_key, size_t start_key_len,
|
|
const char* limit_key, size_t limit_key_len);
|
|
|
|
/* Management operations */
|
|
|
|
extern void rocksdb_destroy_db(
|
|
const rocksdb_options_t* options,
|
|
const char* name,
|
|
char** errptr);
|
|
|
|
extern void rocksdb_repair_db(
|
|
const rocksdb_options_t* options,
|
|
const char* name,
|
|
char** errptr);
|
|
|
|
/* Iterator */
|
|
|
|
extern void rocksdb_iter_destroy(rocksdb_iterator_t*);
|
|
extern unsigned char rocksdb_iter_valid(const rocksdb_iterator_t*);
|
|
extern void rocksdb_iter_seek_to_first(rocksdb_iterator_t*);
|
|
extern void rocksdb_iter_seek_to_last(rocksdb_iterator_t*);
|
|
extern void rocksdb_iter_seek(rocksdb_iterator_t*, const char* k, size_t klen);
|
|
extern void rocksdb_iter_next(rocksdb_iterator_t*);
|
|
extern void rocksdb_iter_prev(rocksdb_iterator_t*);
|
|
extern const char* rocksdb_iter_key(const rocksdb_iterator_t*, size_t* klen);
|
|
extern const char* rocksdb_iter_value(const rocksdb_iterator_t*, size_t* vlen);
|
|
extern void rocksdb_iter_get_error(const rocksdb_iterator_t*, char** errptr);
|
|
|
|
/* Write batch */
|
|
|
|
extern rocksdb_writebatch_t* rocksdb_writebatch_create();
|
|
extern void rocksdb_writebatch_destroy(rocksdb_writebatch_t*);
|
|
extern void rocksdb_writebatch_clear(rocksdb_writebatch_t*);
|
|
extern void rocksdb_writebatch_put(
|
|
rocksdb_writebatch_t*,
|
|
const char* key, size_t klen,
|
|
const char* val, size_t vlen);
|
|
extern void rocksdb_writebatch_delete(
|
|
rocksdb_writebatch_t*,
|
|
const char* key, size_t klen);
|
|
extern void rocksdb_writebatch_iterate(
|
|
rocksdb_writebatch_t*,
|
|
void* state,
|
|
void (*put)(void*, const char* k, size_t klen, const char* v, size_t vlen),
|
|
void (*deleted)(void*, const char* k, size_t klen));
|
|
|
|
/* Options */
|
|
|
|
extern rocksdb_options_t* rocksdb_options_create();
|
|
extern void rocksdb_options_destroy(rocksdb_options_t*);
|
|
extern void rocksdb_options_set_comparator(
|
|
rocksdb_options_t*,
|
|
rocksdb_comparator_t*);
|
|
extern void rocksdb_options_set_compression_per_level(
|
|
rocksdb_options_t* opt,
|
|
int* level_values,
|
|
size_t num_levels);
|
|
extern void rocksdb_options_set_filter_policy(
|
|
rocksdb_options_t*,
|
|
rocksdb_filterpolicy_t*);
|
|
extern void rocksdb_options_set_create_if_missing(
|
|
rocksdb_options_t*, unsigned char);
|
|
extern void rocksdb_options_set_error_if_exists(
|
|
rocksdb_options_t*, unsigned char);
|
|
extern void rocksdb_options_set_paranoid_checks(
|
|
rocksdb_options_t*, unsigned char);
|
|
extern void rocksdb_options_set_env(rocksdb_options_t*, rocksdb_env_t*);
|
|
extern void rocksdb_options_set_info_log(rocksdb_options_t*, rocksdb_logger_t*);
|
|
extern void rocksdb_options_set_write_buffer_size(rocksdb_options_t*, size_t);
|
|
extern void rocksdb_options_set_max_open_files(rocksdb_options_t*, int);
|
|
extern void rocksdb_options_set_cache(rocksdb_options_t*, rocksdb_cache_t*);
|
|
extern void rocksdb_options_set_block_size(rocksdb_options_t*, size_t);
|
|
extern void rocksdb_options_set_block_restart_interval(rocksdb_options_t*, int);
|
|
extern void rocksdb_options_set_compression_options(
|
|
rocksdb_options_t* opt, int w_bits, int level, int strategy);
|
|
|
|
enum {
|
|
rocksdb_no_compression = 0,
|
|
rocksdb_snappy_compression = 1
|
|
};
|
|
extern void rocksdb_options_set_compression(rocksdb_options_t*, int);
|
|
|
|
/* Comparator */
|
|
|
|
extern rocksdb_comparator_t* rocksdb_comparator_create(
|
|
void* state,
|
|
void (*destructor)(void*),
|
|
int (*compare)(
|
|
void*,
|
|
const char* a, size_t alen,
|
|
const char* b, size_t blen),
|
|
const char* (*name)(void*));
|
|
extern void rocksdb_comparator_destroy(rocksdb_comparator_t*);
|
|
|
|
/* Filter policy */
|
|
|
|
extern rocksdb_filterpolicy_t* rocksdb_filterpolicy_create(
|
|
void* state,
|
|
void (*destructor)(void*),
|
|
char* (*create_filter)(
|
|
void*,
|
|
const char* const* key_array, const size_t* key_length_array,
|
|
int num_keys,
|
|
size_t* filter_length),
|
|
unsigned char (*key_may_match)(
|
|
void*,
|
|
const char* key, size_t length,
|
|
const char* filter, size_t filter_length),
|
|
const char* (*name)(void*));
|
|
extern void rocksdb_filterpolicy_destroy(rocksdb_filterpolicy_t*);
|
|
|
|
extern rocksdb_filterpolicy_t* rocksdb_filterpolicy_create_bloom(
|
|
int bits_per_key);
|
|
|
|
/* Read options */
|
|
|
|
extern rocksdb_readoptions_t* rocksdb_readoptions_create();
|
|
extern void rocksdb_readoptions_destroy(rocksdb_readoptions_t*);
|
|
extern void rocksdb_readoptions_set_verify_checksums(
|
|
rocksdb_readoptions_t*,
|
|
unsigned char);
|
|
extern void rocksdb_readoptions_set_fill_cache(
|
|
rocksdb_readoptions_t*, unsigned char);
|
|
extern void rocksdb_readoptions_set_snapshot(
|
|
rocksdb_readoptions_t*,
|
|
const rocksdb_snapshot_t*);
|
|
|
|
/* Write options */
|
|
|
|
extern rocksdb_writeoptions_t* rocksdb_writeoptions_create();
|
|
extern void rocksdb_writeoptions_destroy(rocksdb_writeoptions_t*);
|
|
extern void rocksdb_writeoptions_set_sync(
|
|
rocksdb_writeoptions_t*, unsigned char);
|
|
|
|
/* Cache */
|
|
|
|
extern rocksdb_cache_t* rocksdb_cache_create_lru(size_t capacity);
|
|
extern void rocksdb_cache_destroy(rocksdb_cache_t* cache);
|
|
|
|
/* Env */
|
|
|
|
extern rocksdb_env_t* rocksdb_create_default_env();
|
|
extern void rocksdb_env_destroy(rocksdb_env_t*);
|
|
|
|
#ifdef __cplusplus
|
|
} /* end extern "C" */
|
|
#endif
|
|
|
|
#endif /* STORAGE_ROCKSDB_INCLUDE_C_H_ */
|