Bitcoin
c.h
Go to the documentation of this file.
1 /* Copyright (c) 2011 The LevelDB Authors. All rights reserved.
2  Use of this source code is governed by a BSD-style license that can be
3  found in the LICENSE file. See the AUTHORS file for names of contributors.
4 
5  C bindings for leveldb. May be useful as a stable ABI that can be
6  used by programs that keep leveldb in a shared library, or for
7  a JNI api.
8 
9  Does not support:
10  . getters for the option types
11  . custom comparators that implement key shortening
12  . custom iter, db, env, cache implementations using just the C bindings
13 
14  Some conventions:
15 
16  (1) We expose just opaque struct pointers and functions to clients.
17  This allows us to change internal representations without having to
18  recompile clients.
19 
20  (2) For simplicity, there is no equivalent to the Slice type. Instead,
21  the caller has to pass the pointer and length as separate
22  arguments.
23 
24  (3) Errors are represented by a null-terminated c string. NULL
25  means no error. All operations that can raise an error are passed
26  a "char** errptr" as the last argument. One of the following must
27  be true on entry:
28  *errptr == NULL
29  *errptr points to a malloc()ed null-terminated error message
30  (On Windows, *errptr must have been malloc()-ed by this library.)
31  On success, a leveldb routine leaves *errptr unchanged.
32  On failure, leveldb frees the old value of *errptr and
33  set *errptr to a malloc()ed error message.
34 
35  (4) Bools have the type unsigned char (0 == false; rest == true)
36 
37  (5) All of the pointer arguments must be non-NULL.
38 */
39 
40 #ifndef STORAGE_LEVELDB_INCLUDE_C_H_
41 #define STORAGE_LEVELDB_INCLUDE_C_H_
42 
43 #ifdef __cplusplus
44 extern "C" {
45 #endif
46 
47 #include <stdarg.h>
48 #include <stddef.h>
49 #include <stdint.h>
50 
51 /* Exported types */
52 
53 typedef struct leveldb_t leveldb_t;
69 
70 /* DB operations */
71 
72 extern leveldb_t* leveldb_open(
73  const leveldb_options_t* options,
74  const char* name,
75  char** errptr);
76 
77 extern void leveldb_close(leveldb_t* db);
78 
79 extern void leveldb_put(
80  leveldb_t* db,
81  const leveldb_writeoptions_t* options,
82  const char* key, size_t keylen,
83  const char* val, size_t vallen,
84  char** errptr);
85 
86 extern void leveldb_delete(
87  leveldb_t* db,
88  const leveldb_writeoptions_t* options,
89  const char* key, size_t keylen,
90  char** errptr);
91 
92 extern void leveldb_write(
93  leveldb_t* db,
94  const leveldb_writeoptions_t* options,
95  leveldb_writebatch_t* batch,
96  char** errptr);
97 
98 /* Returns NULL if not found. A malloc()ed array otherwise.
99  Stores the length of the array in *vallen. */
100 extern char* leveldb_get(
101  leveldb_t* db,
102  const leveldb_readoptions_t* options,
103  const char* key, size_t keylen,
104  size_t* vallen,
105  char** errptr);
106 
108  leveldb_t* db,
109  const leveldb_readoptions_t* options);
110 
112  leveldb_t* db);
113 
114 extern void leveldb_release_snapshot(
115  leveldb_t* db,
116  const leveldb_snapshot_t* snapshot);
117 
118 /* Returns NULL if property name is unknown.
119  Else returns a pointer to a malloc()-ed null-terminated value. */
120 extern char* leveldb_property_value(
121  leveldb_t* db,
122  const char* propname);
123 
124 extern void leveldb_approximate_sizes(
125  leveldb_t* db,
126  int num_ranges,
127  const char* const* range_start_key, const size_t* range_start_key_len,
128  const char* const* range_limit_key, const size_t* range_limit_key_len,
129  uint64_t* sizes);
130 
131 extern void leveldb_compact_range(
132  leveldb_t* db,
133  const char* start_key, size_t start_key_len,
134  const char* limit_key, size_t limit_key_len);
135 
136 /* Management operations */
137 
138 extern void leveldb_destroy_db(
139  const leveldb_options_t* options,
140  const char* name,
141  char** errptr);
142 
143 extern void leveldb_repair_db(
144  const leveldb_options_t* options,
145  const char* name,
146  char** errptr);
147 
148 /* Iterator */
149 
151 extern unsigned char leveldb_iter_valid(const leveldb_iterator_t*);
154 extern void leveldb_iter_seek(leveldb_iterator_t*, const char* k, size_t klen);
157 extern const char* leveldb_iter_key(const leveldb_iterator_t*, size_t* klen);
158 extern const char* leveldb_iter_value(const leveldb_iterator_t*, size_t* vlen);
159 extern void leveldb_iter_get_error(const leveldb_iterator_t*, char** errptr);
160 
161 /* Write batch */
162 
166 extern void leveldb_writebatch_put(
168  const char* key, size_t klen,
169  const char* val, size_t vlen);
170 extern void leveldb_writebatch_delete(
172  const char* key, size_t klen);
173 extern void leveldb_writebatch_iterate(
175  void* state,
176  void (*put)(void*, const char* k, size_t klen, const char* v, size_t vlen),
177  void (*deleted)(void*, const char* k, size_t klen));
178 
179 /* Options */
180 
190  leveldb_options_t*, unsigned char);
192  leveldb_options_t*, unsigned char);
194  leveldb_options_t*, unsigned char);
202 
203 enum {
206 };
208 
209 /* Comparator */
210 
212  void* state,
213  void (*destructor)(void*),
214  int (*compare)(
215  void*,
216  const char* a, size_t alen,
217  const char* b, size_t blen),
218  const char* (*name)(void*));
220 
221 /* Filter policy */
222 
224  void* state,
225  void (*destructor)(void*),
226  char* (*create_filter)(
227  void*,
228  const char* const* key_array, const size_t* key_length_array,
229  int num_keys,
230  size_t* filter_length),
231  unsigned char (*key_may_match)(
232  void*,
233  const char* key, size_t length,
234  const char* filter, size_t filter_length),
235  const char* (*name)(void*));
237 
239  int bits_per_key);
240 
241 /* Read options */
242 
247  unsigned char);
249  leveldb_readoptions_t*, unsigned char);
252  const leveldb_snapshot_t*);
253 
254 /* Write options */
255 
259  leveldb_writeoptions_t*, unsigned char);
260 
261 /* Cache */
262 
263 extern leveldb_cache_t* leveldb_cache_create_lru(size_t capacity);
264 extern void leveldb_cache_destroy(leveldb_cache_t* cache);
265 
266 /* Env */
267 
269 extern void leveldb_env_destroy(leveldb_env_t*);
270 
271 /* Utility */
272 
273 /* Calls free(ptr).
274  REQUIRES: ptr was malloc()-ed and returned by one of the routines
275  in this file. Note that in certain cases (typically on Windows), you
276  may need to call this routine instead of free(ptr) to dispose of
277  malloc()-ed memory returned by this library. */
278 extern void leveldb_free(void* ptr);
279 
280 /* Return the major version number for this release. */
281 extern int leveldb_major_version();
282 
283 /* Return the minor version number for this release. */
284 extern int leveldb_minor_version();
285 
286 #ifdef __cplusplus
287 } /* end extern "C" */
288 #endif
289 
290 #endif /* STORAGE_LEVELDB_INCLUDE_C_H_ */
leveldb_env_t * leveldb_create_default_env()
Definition: c.cc:573
void leveldb_put(leveldb_t *db, const leveldb_writeoptions_t *options, const char *key, size_t keylen, const char *val, size_t vallen, char **errptr)
Definition: c.cc:172
leveldb_cache_t * leveldb_cache_create_lru(size_t capacity)
Definition: c.cc:562
const leveldb_snapshot_t * leveldb_create_snapshot(leveldb_t *db)
Definition: c.cc:228
void leveldb_options_set_info_log(leveldb_options_t *, leveldb_logger_t *)
Definition: c.cc:427
void leveldb_options_set_env(leveldb_options_t *, leveldb_env_t *)
Definition: c.cc:423
leveldb_readoptions_t * leveldb_readoptions_create()
Definition: c.cc:524
void leveldb_writeoptions_destroy(leveldb_writeoptions_t *)
Definition: c.cc:553
leveldb_t * leveldb_open(const leveldb_options_t *options, const char *name, char **errptr)
Definition: c.cc:154
Definition: c.cc:58
void leveldb_free(void *ptr)
Definition: c.cc:585
const char * leveldb_iter_value(const leveldb_iterator_t *, size_t *vlen)
Definition: c.cc:329
void leveldb_writeoptions_set_sync(leveldb_writeoptions_t *, unsigned char)
Definition: c.cc:557
void leveldb_readoptions_destroy(leveldb_readoptions_t *)
Definition: c.cc:528
leveldb_filterpolicy_t * leveldb_filterpolicy_create_bloom(int bits_per_key)
Definition: c.cc:501
void leveldb_iter_seek_to_last(leveldb_iterator_t *)
Definition: c.cc:307
Definition: c.cc:53
leveldb_filterpolicy_t * leveldb_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 *))
Definition: c.cc:475
Definition: c.cc:59
Definition: c.cc:48
void leveldb_options_set_error_if_exists(leveldb_options_t *, unsigned char)
Definition: c.cc:413
Definition: c.cc:62
void leveldb_repair_db(const leveldb_options_t *options, const char *name, char **errptr)
Definition: c.cc:287
Definition: c.cc:52
leveldb_comparator_t * leveldb_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 *))
Definition: c.cc:455
void leveldb_iter_destroy(leveldb_iterator_t *)
Definition: c.cc:294
leveldb_writebatch_t * leveldb_writebatch_create()
Definition: c.cc:339
void leveldb_release_snapshot(leveldb_t *db, const leveldb_snapshot_t *snapshot)
Definition: c.cc:235
Definition: c.h:204
void leveldb_options_set_block_restart_interval(leveldb_options_t *, int)
Definition: c.cc:447
void leveldb_writebatch_put(leveldb_writebatch_t *, const char *key, size_t klen, const char *val, size_t vlen)
Definition: c.cc:351
void leveldb_options_set_comparator(leveldb_options_t *, leveldb_comparator_t *)
Definition: c.cc:396
leveldb_options_t * leveldb_options_create()
Definition: c.cc:388
char * leveldb_get(leveldb_t *db, const leveldb_readoptions_t *options, const char *key, size_t keylen, size_t *vallen, char **errptr)
Definition: c.cc:199
void leveldb_iter_prev(leveldb_iterator_t *)
Definition: c.cc:319
void leveldb_destroy_db(const leveldb_options_t *options, const char *name, char **errptr)
Definition: c.cc:280
void leveldb_writebatch_destroy(leveldb_writebatch_t *)
Definition: c.cc:343
int leveldb_major_version()
Definition: c.cc:589
void leveldb_options_set_max_open_files(leveldb_options_t *, int)
Definition: c.cc:435
Definition: c.cc:60
const char * leveldb_iter_key(const leveldb_iterator_t *, size_t *klen)
Definition: c.cc:323
void leveldb_iter_seek(leveldb_iterator_t *, const char *k, size_t klen)
Definition: c.cc:311
const char * name
Definition: rest.cpp:39
void leveldb_options_set_cache(leveldb_options_t *, leveldb_cache_t *)
Definition: c.cc:439
unsigned long long uint64_t
Definition: stdint.h:22
void leveldb_close(leveldb_t *db)
Definition: c.cc:167
int leveldb_minor_version()
Definition: c.cc:593
void leveldb_options_set_paranoid_checks(leveldb_options_t *, unsigned char)
Definition: c.cc:418
void leveldb_cache_destroy(leveldb_cache_t *cache)
Definition: c.cc:568
void leveldb_iter_next(leveldb_iterator_t *)
Definition: c.cc:315
void leveldb_delete(leveldb_t *db, const leveldb_writeoptions_t *options, const char *key, size_t keylen, char **errptr)
Definition: c.cc:182
void leveldb_options_set_write_buffer_size(leveldb_options_t *, size_t)
Definition: c.cc:431
leveldb_writeoptions_t * leveldb_writeoptions_create()
Definition: c.cc:549
void leveldb_readoptions_set_verify_checksums(leveldb_readoptions_t *, unsigned char)
Definition: c.cc:532
void leveldb_approximate_sizes(leveldb_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)
Definition: c.cc:254
Definition: c.cc:129
void leveldb_writebatch_iterate(leveldb_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))
Definition: c.cc:364
void leveldb_compact_range(leveldb_t *db, const char *start_key, size_t start_key_len, const char *limit_key, size_t limit_key_len)
Definition: c.cc:269
Definition: c.cc:55
unsigned char leveldb_iter_valid(const leveldb_iterator_t *)
Definition: c.cc:299
leveldb_iterator_t * leveldb_create_iterator(leveldb_t *db, const leveldb_readoptions_t *options)
Definition: c.cc:220
void leveldb_readoptions_set_snapshot(leveldb_readoptions_t *, const leveldb_snapshot_t *)
Definition: c.cc:543
void leveldb_writebatch_delete(leveldb_writebatch_t *, const char *key, size_t klen)
Definition: c.cc:358
void leveldb_options_set_create_if_missing(leveldb_options_t *, unsigned char)
Definition: c.cc:408
Definition: c.cc:88
char * leveldb_property_value(leveldb_t *db, const char *propname)
Definition: c.cc:242
void leveldb_filterpolicy_destroy(leveldb_filterpolicy_t *)
Definition: c.cc:497
Definition: c.cc:54
void leveldb_iter_get_error(const leveldb_iterator_t *, char **errptr)
Definition: c.cc:335
Definition: c.cc:56
void leveldb_options_set_filter_policy(leveldb_options_t *, leveldb_filterpolicy_t *)
Definition: c.cc:402
Definition: c.cc:51
void leveldb_options_destroy(leveldb_options_t *)
Definition: c.cc:392
void leveldb_comparator_destroy(leveldb_comparator_t *)
Definition: c.cc:471
void leveldb_options_set_block_size(leveldb_options_t *, size_t)
Definition: c.cc:443
void leveldb_writebatch_clear(leveldb_writebatch_t *)
Definition: c.cc:347
void leveldb_iter_seek_to_first(leveldb_iterator_t *)
Definition: c.cc:303
Definition: c.cc:50
void leveldb_env_destroy(leveldb_env_t *)
Definition: c.cc:580
Definition: c.cc:57
Definition: c.cc:49
Definition: c.h:205
void leveldb_write(leveldb_t *db, const leveldb_writeoptions_t *options, leveldb_writebatch_t *batch, char **errptr)
Definition: c.cc:191
key
Definition: extract_strings_qt.py:80
void leveldb_readoptions_set_fill_cache(leveldb_readoptions_t *, unsigned char)
Definition: c.cc:538
void leveldb_options_set_compression(leveldb_options_t *, int)
Definition: c.cc:451