|
|
@ -1,5 +1,7 @@ |
|
|
|
use libc::c_uint; |
|
|
|
use libc::c_uint; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
use ffi::*; |
|
|
|
|
|
|
|
|
|
|
|
bitflags! { |
|
|
|
bitflags! { |
|
|
|
#[doc="Environment Options"] |
|
|
|
#[doc="Environment Options"] |
|
|
|
#[deriving(Show)] |
|
|
|
#[deriving(Show)] |
|
|
@ -12,25 +14,25 @@ bitflags! { |
|
|
|
#[doc="across multiple invocations. This option may not always work, depending on"] |
|
|
|
#[doc="across multiple invocations. This option may not always work, depending on"] |
|
|
|
#[doc="how the operating system has allocated memory to shared libraries and other uses."] |
|
|
|
#[doc="how the operating system has allocated memory to shared libraries and other uses."] |
|
|
|
#[doc="The feature is highly experimental."] |
|
|
|
#[doc="The feature is highly experimental."] |
|
|
|
const FIXED_MAP = 0x01, |
|
|
|
const FIXED_MAP = MDB_FIXEDMAP, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="By default, LMDB creates its environment in a directory whose pathname is given in"] |
|
|
|
#[doc="By default, LMDB creates its environment in a directory whose pathname is given in"] |
|
|
|
#[doc="`path`, and creates its data and lock files under that directory. With this option,"] |
|
|
|
#[doc="`path`, and creates its data and lock files under that directory. With this option,"] |
|
|
|
#[doc="`path` is used as-is for the database main data file. The database lock file is the"] |
|
|
|
#[doc="`path` is used as-is for the database main data file. The database lock file is the"] |
|
|
|
#[doc="`path` with `-lock` appended."] |
|
|
|
#[doc="`path` with `-lock` appended."] |
|
|
|
const NO_SUB_DIR = 0x4000, |
|
|
|
const NO_SUB_DIR = MDB_NOSUBDIR, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Use a writeable memory map unless `READ_ONLY` is set. This is faster and uses"] |
|
|
|
#[doc="Use a writeable memory map unless `READ_ONLY` is set. This is faster and uses"] |
|
|
|
#[doc="fewer mallocs, but loses protection from application bugs like wild pointer writes"] |
|
|
|
#[doc="fewer mallocs, but loses protection from application bugs like wild pointer writes"] |
|
|
|
#[doc="and other bad updates into the database. Incompatible with nested transactions."] |
|
|
|
#[doc="and other bad updates into the database. Incompatible with nested transactions."] |
|
|
|
#[doc="Processes with and without `WRITEMAP` on the same environment do not cooperate"] |
|
|
|
#[doc="Processes with and without `WRITE_MAP` on the same environment do not cooperate"] |
|
|
|
#[doc="well."] |
|
|
|
#[doc="well."] |
|
|
|
const WRITEMAP = 0x80000, |
|
|
|
const WRITE_MAP = MDB_WRITEMAP, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Open the environment in read-only mode. No write operations will be allowed."] |
|
|
|
#[doc="Open the environment in read-only mode. No write operations will be allowed."] |
|
|
|
#[doc="When opening an environment, LMDB will still modify the lock file - except on"] |
|
|
|
#[doc="When opening an environment, LMDB will still modify the lock file - except on"] |
|
|
|
#[doc="read-only filesystems, where LMDB does not use locks."] |
|
|
|
#[doc="read-only filesystems, where LMDB does not use locks."] |
|
|
|
const READ_ONLY = 0x20000, |
|
|
|
const READ_ONLY = MDB_RDONLY, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Flush system buffers to disk only once per transaction, omit the metadata flush."] |
|
|
|
#[doc="Flush system buffers to disk only once per transaction, omit the metadata flush."] |
|
|
|
#[doc="Defer that until the system flushes files to disk, or next non-`READ_ONLY` commit"] |
|
|
|
#[doc="Defer that until the system flushes files to disk, or next non-`READ_ONLY` commit"] |
|
|
@ -38,26 +40,26 @@ bitflags! { |
|
|
|
#[doc="system crash may undo the last committed transaction. I.e. it preserves the ACI"] |
|
|
|
#[doc="system crash may undo the last committed transaction. I.e. it preserves the ACI"] |
|
|
|
#[doc="(atomicity, consistency, isolation) but not D (durability) database property."] |
|
|
|
#[doc="(atomicity, consistency, isolation) but not D (durability) database property."] |
|
|
|
#[doc="\n\nThis flag may be changed at any time using `Environment::set_flags`."] |
|
|
|
#[doc="\n\nThis flag may be changed at any time using `Environment::set_flags`."] |
|
|
|
const NO_META_SYNC = 0x40000, |
|
|
|
const NO_META_SYNC = MDB_NOMETASYNC, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Don't flush system buffers to disk when committing a transaction. This optimization"] |
|
|
|
#[doc="Don't flush system buffers to disk when committing a transaction. This optimization"] |
|
|
|
#[doc="means a system crash can corrupt the database or lose the last transactions if"] |
|
|
|
#[doc="means a system crash can corrupt the database or lose the last transactions if"] |
|
|
|
#[doc="buffers are not yet flushed to disk. The risk is governed by how often the system"] |
|
|
|
#[doc="buffers are not yet flushed to disk. The risk is governed by how often the system"] |
|
|
|
#[doc="flushes dirty buffers to disk and how often `Environment::sync` is called. However,"] |
|
|
|
#[doc="flushes dirty buffers to disk and how often `Environment::sync` is called. However,"] |
|
|
|
#[doc="if the filesystem preserves write order and the `WRITEMAP` flag is not used,"] |
|
|
|
#[doc="if the filesystem preserves write order and the `WRITE_MAP` flag is not used,"] |
|
|
|
#[doc="transactions exhibit ACI (atomicity, consistency, isolation) properties and only"] |
|
|
|
#[doc="transactions exhibit ACI (atomicity, consistency, isolation) properties and only"] |
|
|
|
#[doc="lose D (durability). I.e. database integrity"] #[doc="is maintained, but a system"] |
|
|
|
#[doc="lose D (durability). I.e. database integrity"] #[doc="is maintained, but a system"] |
|
|
|
#[doc="crash may undo the final transactions. Note that (`NO_SYNC | WRITEMAP`) leaves the"] |
|
|
|
#[doc="crash may undo the final transactions. Note that (`NO_SYNC | WRITE_MAP`) leaves the"] |
|
|
|
#[doc="system with no hint for when to write transactions to disk, unless"] |
|
|
|
#[doc="system with no hint for when to write transactions to disk, unless"] |
|
|
|
#[doc="`Environment::sync` is called. (`MAP_ASYNC | WRITEMAP`) may be preferable."] |
|
|
|
#[doc="`Environment::sync` is called. (`MAP_ASYNC | WRITE_MAP`) may be preferable."] |
|
|
|
#[doc="\n\nThis flag may be changed at any time using `Environment::set_flags`."] |
|
|
|
#[doc="\n\nThis flag may be changed at any time using `Environment::set_flags`."] |
|
|
|
const NO_SYNC = 0x10000, |
|
|
|
const NO_SYNC = MDB_NOSYNC, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="When using `WRITEMAP`, use asynchronous flushes to disk. As with `NO_SYNC`, a"] |
|
|
|
#[doc="When using `WRITE_MAP`, use asynchronous flushes to disk. As with `NO_SYNC`, a"] |
|
|
|
#[doc="system crash can then corrupt the database or lose the last transactions. Calling"] |
|
|
|
#[doc="system crash can then corrupt the database or lose the last transactions. Calling"] |
|
|
|
#[doc="`Environment::sync` ensures on-disk database integrity until next commit."] |
|
|
|
#[doc="`Environment::sync` ensures on-disk database integrity until next commit."] |
|
|
|
#[doc="\n\nThis flag may be changed at any time using `Environment::set_flags`."] |
|
|
|
#[doc="\n\nThis flag may be changed at any time using `Environment::set_flags`."] |
|
|
|
const MAP_ASYNC = 0x100000, |
|
|
|
const MAP_ASYNC = MDB_MAPASYNC, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Don't use thread-local storage. Tie reader locktable slots to transaction objects"] |
|
|
|
#[doc="Don't use thread-local storage. Tie reader locktable slots to transaction objects"] |
|
|
|
#[doc="instead of to threads. I.e. `RoTransaction::reset` keeps the slot reseved for the"] |
|
|
|
#[doc="instead of to threads. I.e. `RoTransaction::reset` keeps the slot reseved for the"] |
|
|
@ -67,20 +69,20 @@ bitflags! { |
|
|
|
#[doc="threads over individual OS threads need this option. Such an application must also"] |
|
|
|
#[doc="threads over individual OS threads need this option. Such an application must also"] |
|
|
|
#[doc="serialize the write transactions in an OS thread, since LMDB's write locking is"] |
|
|
|
#[doc="serialize the write transactions in an OS thread, since LMDB's write locking is"] |
|
|
|
#[doc="unaware of the user threads."] |
|
|
|
#[doc="unaware of the user threads."] |
|
|
|
const NO_TLS = 0x200000, |
|
|
|
const NO_TLS = MDB_NOTLS, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Do not do any locking. If concurrent access is anticipated, the caller must manage"] |
|
|
|
#[doc="Do not do any locking. If concurrent access is anticipated, the caller must manage"] |
|
|
|
#[doc="all concurrency themself. For proper operation the caller must enforce"] |
|
|
|
#[doc="all concurrency themself. For proper operation the caller must enforce"] |
|
|
|
#[doc="single-writer semantics, and must ensure that no readers are using old"] |
|
|
|
#[doc="single-writer semantics, and must ensure that no readers are using old"] |
|
|
|
#[doc="transactions while a writer is active. The simplest approach is to use an exclusive"] |
|
|
|
#[doc="transactions while a writer is active. The simplest approach is to use an exclusive"] |
|
|
|
#[doc="lock so that no readers may be active at all when a writer begins."] |
|
|
|
#[doc="lock so that no readers may be active at all when a writer begins."] |
|
|
|
const NO_LOCK = 0x400000, |
|
|
|
const NO_LOCK = MDB_NOLOCK, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Turn off readahead. Most operating systems perform readahead on read requests by"] |
|
|
|
#[doc="Turn off readahead. Most operating systems perform readahead on read requests by"] |
|
|
|
#[doc="default. This option turns it off if the OS supports it. Turning it off may help"] |
|
|
|
#[doc="default. This option turns it off if the OS supports it. Turning it off may help"] |
|
|
|
#[doc="random read performance when the DB is larger than RAM and system RAM is full."] |
|
|
|
#[doc="random read performance when the DB is larger than RAM and system RAM is full."] |
|
|
|
#[doc="The option is not implemented on Windows."] |
|
|
|
#[doc="The option is not implemented on Windows."] |
|
|
|
const NO_READAHEAD = 0x800000, |
|
|
|
const NO_READAHEAD = MDB_NORDAHEAD, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Do not initialize malloc'd memory before writing to unused spaces in the data file."] |
|
|
|
#[doc="Do not initialize malloc'd memory before writing to unused spaces in the data file."] |
|
|
|
#[doc="By default, memory for pages written to the data file is obtained using malloc."] |
|
|
|
#[doc="By default, memory for pages written to the data file is obtained using malloc."] |
|
|
@ -92,12 +94,12 @@ bitflags! { |
|
|
|
#[doc="initialization step has a modest performance cost so some applications may want to"] |
|
|
|
#[doc="initialization step has a modest performance cost so some applications may want to"] |
|
|
|
#[doc="disable it using this flag. This option can be a problem for applications which"] |
|
|
|
#[doc="disable it using this flag. This option can be a problem for applications which"] |
|
|
|
#[doc="handle sensitive data like passwords, and it makes memory checkers like Valgrind"] |
|
|
|
#[doc="handle sensitive data like passwords, and it makes memory checkers like Valgrind"] |
|
|
|
#[doc="noisy. This flag is not needed with `WRITEMAP`, which writes directly to the mmap"] |
|
|
|
#[doc="noisy. This flag is not needed with `WRITE_MAP`, which writes directly to the mmap"] |
|
|
|
#[doc="instead of using malloc for pages. The initialization is also skipped if writing"] |
|
|
|
#[doc="instead of using malloc for pages. The initialization is also skipped if writing"] |
|
|
|
#[doc="with reserve; the caller is expected to overwrite all of the memory that was"] |
|
|
|
#[doc="with reserve; the caller is expected to overwrite all of the memory that was"] |
|
|
|
#[doc="reserved in that case."] |
|
|
|
#[doc="reserved in that case."] |
|
|
|
#[doc="\n\nThis flag may be changed at any time using `Environment::set_flags`."] |
|
|
|
#[doc="\n\nThis flag may be changed at any time using `Environment::set_flags`."] |
|
|
|
const NO_MEM_INIT = 0x1000000, |
|
|
|
const NO_MEM_INIT = MDB_NOMEMINIT, |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -109,31 +111,31 @@ bitflags! { |
|
|
|
#[doc="Keys are strings to be compared in reverse order, from the end of the strings"] |
|
|
|
#[doc="Keys are strings to be compared in reverse order, from the end of the strings"] |
|
|
|
#[doc="to the beginning. By default, Keys are treated as strings and compared from"] |
|
|
|
#[doc="to the beginning. By default, Keys are treated as strings and compared from"] |
|
|
|
#[doc="beginning to end."] |
|
|
|
#[doc="beginning to end."] |
|
|
|
const REVERSE_KEY = 0x02, |
|
|
|
const REVERSE_KEY = MDB_REVERSEKEY, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Duplicate keys may be used in the database. (Or, from another perspective,"] |
|
|
|
#[doc="Duplicate keys may be used in the database. (Or, from another perspective,"] |
|
|
|
#[doc="keys may have multiple data items, stored in sorted order.) By default"] |
|
|
|
#[doc="keys may have multiple data items, stored in sorted order.) By default"] |
|
|
|
#[doc="keys must be unique and may have only a single data item."] |
|
|
|
#[doc="keys must be unique and may have only a single data item."] |
|
|
|
const DUP_SORT = 0x04, |
|
|
|
const DUP_SORT = MDB_DUPSORT, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Keys are binary integers in native byte order. Setting this option requires all"] |
|
|
|
#[doc="Keys are binary integers in native byte order. Setting this option requires all"] |
|
|
|
#[doc="keys to be the same size, typically 32 or 64 bits."] |
|
|
|
#[doc="keys to be the same size, typically 32 or 64 bits."] |
|
|
|
const INTEGER_KEY = 0x08, |
|
|
|
const INTEGER_KEY = MDB_INTEGERKEY, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="This flag may only be used in combination with `DUP_SORT`. This option tells"] |
|
|
|
#[doc="This flag may only be used in combination with `DUP_SORT`. This option tells"] |
|
|
|
#[doc="the library that the data items for this database are all the same size, which"] |
|
|
|
#[doc="the library that the data items for this database are all the same size, which"] |
|
|
|
#[doc="allows further optimizations in storage and retrieval. When all data items are"] |
|
|
|
#[doc="allows further optimizations in storage and retrieval. When all data items are"] |
|
|
|
#[doc="the same size, the `GET_MULTIPLE` and `NEXT_MULTIPLE` cursor operations may be"] |
|
|
|
#[doc="the same size, the `GET_MULTIPLE` and `NEXT_MULTIPLE` cursor operations may be"] |
|
|
|
#[doc="used to retrieve multiple items at once."] |
|
|
|
#[doc="used to retrieve multiple items at once."] |
|
|
|
const DUP_FIXED = 0x10, |
|
|
|
const DUP_FIXED = MDB_DUPFIXED, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="This option specifies that duplicate data items are also integers, and"] |
|
|
|
#[doc="This option specifies that duplicate data items are also integers, and"] |
|
|
|
#[doc="should be sorted as such."] |
|
|
|
#[doc="should be sorted as such."] |
|
|
|
const INTEGER_DUP = 0x20, |
|
|
|
const INTEGER_DUP = MDB_INTEGERDUP, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="This option specifies that duplicate data items should be compared as strings"] |
|
|
|
#[doc="This option specifies that duplicate data items should be compared as strings"] |
|
|
|
#[doc="in reverse order."] |
|
|
|
#[doc="in reverse order."] |
|
|
|
const REVERSE_DUP = 0x40, |
|
|
|
const REVERSE_DUP = MDB_REVERSEDUP, |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -145,27 +147,27 @@ bitflags! { |
|
|
|
#[doc="Insert the new item only if the key does not already appear in the database."] |
|
|
|
#[doc="Insert the new item only if the key does not already appear in the database."] |
|
|
|
#[doc="The function will return `LmdbError::KeyExist` if the key already appears in the"] |
|
|
|
#[doc="The function will return `LmdbError::KeyExist` if the key already appears in the"] |
|
|
|
#[doc="database, even if the database supports duplicates (`DUP_SORT`)."] |
|
|
|
#[doc="database, even if the database supports duplicates (`DUP_SORT`)."] |
|
|
|
const NO_OVERWRITE = 0x10, |
|
|
|
const NO_OVERWRITE = MDB_NOOVERWRITE, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Insert the new item only if it does not already appear in the database."] |
|
|
|
#[doc="Insert the new item only if it does not already appear in the database."] |
|
|
|
#[doc="This flag may only be specified if the database was opened with `DUP_SORT`."] |
|
|
|
#[doc="This flag may only be specified if the database was opened with `DUP_SORT`."] |
|
|
|
#[doc="The function will return `LmdbError::KeyExist` if the item already appears in the"] |
|
|
|
#[doc="The function will return `LmdbError::KeyExist` if the item already appears in the"] |
|
|
|
#[doc="database."] |
|
|
|
#[doc="database."] |
|
|
|
const NO_DUP_DATA = 0x20, |
|
|
|
const NO_DUP_DATA = MDB_NODUPDATA, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="For `Cursor::put`. Replace the item at the current cursor position. The key"] |
|
|
|
#[doc="For `Cursor::put`. Replace the item at the current cursor position. The key"] |
|
|
|
#[doc="parameter must match the current position. If using sorted duplicates (`DUP_SORT`)"] |
|
|
|
#[doc="parameter must match the current position. If using sorted duplicates (`DUP_SORT`)"] |
|
|
|
#[doc="the data item must still sort into the same position. This is intended to be used"] |
|
|
|
#[doc="the data item must still sort into the same position. This is intended to be used"] |
|
|
|
#[doc="when the new data is the same size as the old. Otherwise it will simply perform a"] |
|
|
|
#[doc="when the new data is the same size as the old. Otherwise it will simply perform a"] |
|
|
|
#[doc="delete of the old record followed by an insert."] |
|
|
|
#[doc="delete of the old record followed by an insert."] |
|
|
|
const CURRENT = 0x40, |
|
|
|
const CURRENT = MDB_CURRENT, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Append the given item to the end of the database. No key comparisons are performed."] |
|
|
|
#[doc="Append the given item to the end of the database. No key comparisons are performed."] |
|
|
|
#[doc="This option allows fast bulk loading when keys are already known to be in the"] |
|
|
|
#[doc="This option allows fast bulk loading when keys are already known to be in the"] |
|
|
|
#[doc="correct order. Loading unsorted keys with this flag will cause data corruption."] |
|
|
|
#[doc="correct order. Loading unsorted keys with this flag will cause data corruption."] |
|
|
|
const APPEND = 0x20000, |
|
|
|
const APPEND = MDB_APPEND, |
|
|
|
|
|
|
|
|
|
|
|
#[doc="Same as `APPEND`, but for sorted dup data."] |
|
|
|
#[doc="Same as `APPEND`, but for sorted dup data."] |
|
|
|
const APPEND_DUP = 0x40000, |
|
|
|
const APPEND_DUP = MDB_APPENDDUP, |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|