| Portability | non-portable | 
|---|---|
| Stability | experimental | 
| Maintainer | kim.altintop@gmail.com | 
| Safe Haskell | None | 
Database.LevelDB
Contents
Description
LevelDB Haskell binding.
The API closely follows the C-API of LevelDB. For more information, see: http://leveldb.googlecode.com
- data DB
- data BatchOp
- newtype Comparator = Comparator (ByteString -> ByteString -> Ordering)
- data Compression - = NoCompression
- | Snappy
 
- data Options = Options {- blockRestartInterval :: !Int
- blockSize :: !Int
- cacheSize :: !Int
- comparator :: !(Maybe Comparator)
- compression :: !Compression
- createIfMissing :: !Bool
- errorIfExists :: !Bool
- maxOpenFiles :: !Int
- paranoidChecks :: !Bool
- writeBufferSize :: !Int
 
- data ReadOptions = ReadOptions {- verifyCheckSums :: !Bool
- fillCache :: !Bool
- useSnapshot :: !(Maybe Snapshot)
 
- data Snapshot
- type WriteBatch = [BatchOp]
- data WriteOptions = WriteOptions {}
- type Range = (ByteString, ByteString)
- defaultOptions :: Options
- defaultWriteOptions :: WriteOptions
- defaultReadOptions :: ReadOptions
- withSnapshot :: MonadResource m => DB -> (Snapshot -> m a) -> m a
- open :: MonadResource m => FilePath -> Options -> m DB
- put :: MonadResource m => DB -> WriteOptions -> ByteString -> ByteString -> m ()
- delete :: MonadResource m => DB -> WriteOptions -> ByteString -> m ()
- write :: MonadResource m => DB -> WriteOptions -> WriteBatch -> m ()
- get :: MonadResource m => DB -> ReadOptions -> ByteString -> m (Maybe ByteString)
- createSnapshot :: MonadResource m => DB -> m Snapshot
- createSnapshot' :: MonadResource m => DB -> m (ReleaseKey, Snapshot)
- data Property - = NumFilesAtLevel Int
- | Stats
- | SSTables
 
- getProperty :: MonadResource m => DB -> Property -> m (Maybe ByteString)
- destroy :: MonadResource m => FilePath -> Options -> m ()
- repair :: MonadResource m => FilePath -> Options -> m ()
- approximateSize :: MonadResource m => DB -> Range -> m Int64
- data Iterator
- withIterator :: MonadResource m => DB -> ReadOptions -> (Iterator -> m a) -> m a
- iterOpen :: MonadResource m => DB -> ReadOptions -> m Iterator
- iterOpen' :: MonadResource m => DB -> ReadOptions -> m (ReleaseKey, Iterator)
- iterValid :: MonadResource m => Iterator -> m Bool
- iterSeek :: MonadResource m => Iterator -> ByteString -> m ()
- iterFirst :: MonadResource m => Iterator -> m ()
- iterLast :: MonadResource m => Iterator -> m ()
- iterNext :: MonadResource m => Iterator -> m ()
- iterPrev :: MonadResource m => Iterator -> m ()
- iterKey :: MonadResource m => Iterator -> m (Maybe ByteString)
- iterValue :: MonadResource m => Iterator -> m (Maybe ByteString)
- iterGetError :: MonadResource m => Iterator -> m (Maybe ByteString)
- mapIter :: MonadResource m => (Iterator -> m a) -> Iterator -> m [a]
- iterItems :: MonadResource m => Iterator -> m [(ByteString, ByteString)]
- iterKeys :: MonadResource m => Iterator -> m [ByteString]
- iterValues :: MonadResource m => Iterator -> m [ByteString]
- class (MonadThrow m, MonadUnsafeIO m, MonadIO m, Applicative m) => MonadResource m where- liftResourceT :: ResourceT IO a -> m a
 
- runResourceT :: MonadBaseControl IO m => ResourceT m a -> m a
- resourceForkIO :: MonadBaseControl IO m => ResourceT m () -> ResourceT m ThreadId
Exported Types
Batch operation
Constructors
| Put ByteString ByteString | |
| Del ByteString | 
newtype Comparator Source
User-defined comparator
Constructors
| Comparator (ByteString -> ByteString -> Ordering) | 
Options when opening a database
Constructors
| Options | |
| Fields 
 | |
data ReadOptions Source
Options for read operations
Constructors
| ReadOptions | |
| Fields 
 | |
Instances
type WriteBatch = [BatchOp]Source
data WriteOptions Source
Options for write operations
Constructors
| WriteOptions | |
| Fields 
 | |
Instances
type Range = (ByteString, ByteString)Source
Defaults
Basic Database Manipulation
withSnapshot :: MonadResource m => DB -> (Snapshot -> m a) -> m aSource
Run an action with a snapshot of the database.
The snapshot will be released when the action terminates or throws an exception. Note that this function is provided for convenience and does not prevent the Snapshot handle to escape. It will, however, be invalid after this function returns and should not be used anymore. 
open :: MonadResource m => FilePath -> Options -> m DBSource
Open a database
The returned handle will automatically be released when the enclosing runResourceT terminates. 
put :: MonadResource m => DB -> WriteOptions -> ByteString -> ByteString -> m ()Source
Write a key/value pair
delete :: MonadResource m => DB -> WriteOptions -> ByteString -> m ()Source
Delete a key/value pair
write :: MonadResource m => DB -> WriteOptions -> WriteBatch -> m ()Source
Perform a batch mutation
get :: MonadResource m => DB -> ReadOptions -> ByteString -> m (Maybe ByteString)Source
Read a value by key
createSnapshot :: MonadResource m => DB -> m SnapshotSource
Create a snapshot of the database.
The returned Snapshot will be released automatically when the enclosing runResourceT terminates. It is recommended to use createSnapshot' instead and release the resource manually as soon as possible. 
createSnapshot' :: MonadResource m => DB -> m (ReleaseKey, Snapshot)Source
Create a snapshot of the database which can (and should) be released early.
Administrative Functions
Properties exposed by LevelDB
Constructors
| NumFilesAtLevel Int | |
| Stats | |
| SSTables | 
getProperty :: MonadResource m => DB -> Property -> m (Maybe ByteString)Source
Get a DB property
destroy :: MonadResource m => FilePath -> Options -> m ()Source
Destroy the given leveldb database.
repair :: MonadResource m => FilePath -> Options -> m ()Source
Repair the given leveldb database.
approximateSize :: MonadResource m => DB -> Range -> m Int64Source
Inspect the approximate sizes of the different levels
Iteration
withIterator :: MonadResource m => DB -> ReadOptions -> (Iterator -> m a) -> m aSource
Run an action with an Iterator. The iterator will be closed after the action returns or an error is thrown. Thus, the iterator will not be valid after this function terminates.
iterOpen :: MonadResource m => DB -> ReadOptions -> m IteratorSource
Create an Iterator. 
The iterator will be released when the enclosing runResourceT terminates. You may consider to use iterOpen' instead and manually release the iterator as soon as it is no longer needed (alternatively, use withIterator). 
Note that an Iterator creates a snapshot of the database implicitly, so updates written after the iterator was created are not visible. You may, however, specify an older Snapshot in the ReadOptions. 
iterOpen' :: MonadResource m => DB -> ReadOptions -> m (ReleaseKey, Iterator)Source
Create an Iterator which can be released early. 
iterValid :: MonadResource m => Iterator -> m BoolSource
An iterator is either positioned at a key/value pair, or not valid. This function returns true iff the iterator is valid.
iterSeek :: MonadResource m => Iterator -> ByteString -> m ()Source
Position at the first key in the source that is at or past target. The iterator is valid after this call iff the source contains an entry that comes at or past target.
iterFirst :: MonadResource m => Iterator -> m ()Source
Position at the first key in the source. The iterator is valid after this call iff the source is not empty.
iterLast :: MonadResource m => Iterator -> m ()Source
Position at the last key in the source. The iterator is valid after this call iff the source is not empty.
iterNext :: MonadResource m => Iterator -> m ()Source
Moves to the next entry in the source. After this call, iterValid is true iff the iterator was not positioned at the last entry in the source. 
If the iterator is not valid, this function does nothing. Note that this is a shortcoming of the C API: an iterPrev might still be possible, but we can't determine if we're at the last or first entry. 
iterPrev :: MonadResource m => Iterator -> m ()Source
Moves to the previous entry in the source. After this call, iterValid is true iff the iterator was not positioned at the first entry in the source. 
If the iterator is not valid, this function does nothing. Note that this is a shortcoming of the C API: an iterNext might still be possible, but we can't determine if we're at the last or first entry. 
iterKey :: MonadResource m => Iterator -> m (Maybe ByteString)Source
Return the key for the current entry if the iterator is currently positioned at an entry, ie. iterValid. 
iterValue :: MonadResource m => Iterator -> m (Maybe ByteString)Source
Return the value for the current entry if the iterator is currently positioned at an entry, ie. iterValid. 
iterGetError :: MonadResource m => Iterator -> m (Maybe ByteString)Source
Check for errors
Note that this captures somewhat severe errors such as a corrupted database.
mapIter :: MonadResource m => (Iterator -> m a) -> Iterator -> m [a]Source
Map a function over an iterator, advancing the iterator forward and returning the value. The iterator should be put in the right position prior to calling the function.
Note that this function accumulates the result strictly, ie. it reads all values into memory until the iterator is exhausted. This is most likely not what you want for large ranges. You may consider using conduits instead, for an example see: https://gist.github.com/adc8ec348f03483446a5
iterItems :: MonadResource m => Iterator -> m [(ByteString, ByteString)]Source
Return a list of key and value tuples from an iterator. The iterator should be put in the right position prior to calling this with the iterator.
See strictness remarks on mapIter. 
iterKeys :: MonadResource m => Iterator -> m [ByteString]Source
Return a list of key from an iterator. The iterator should be put in the right position prior to calling this with the iterator.
See strictness remarks on mapIter 
iterValues :: MonadResource m => Iterator -> m [ByteString]Source
Return a list of values from an iterator. The iterator should be put in the right position prior to calling this with the iterator.
See strictness remarks on mapIter 
Re-exports
class (MonadThrow m, MonadUnsafeIO m, MonadIO m, Applicative m) => MonadResource m where
A Monad which allows for safe resource allocation. In theory, any monad transformer stack included a ResourceT can be an instance of MonadResource. 
Note: runResourceT has a requirement for a MonadBaseControl IO m monad, which allows control operations to be lifted. A MonadResource does not have this requirement. This means that transformers such as ContT can be an instance of MonadResource. However, the ContT wrapper will need to be unwrapped before calling runResourceT. 
Since 0.3.0
Methods
liftResourceT :: ResourceT IO a -> m a
Lift a ResourceT IO action into the current Monad. 
Since 0.4.0
Instances
| MonadResource m => MonadResource (ListT m) | |
| (MonadThrow m, MonadUnsafeIO m, MonadIO m, Applicative m) => MonadResource (ResourceT m) | |
| MonadResource m => MonadResource (ExceptionT m) | |
| MonadResource m => MonadResource (MaybeT m) | |
| MonadResource m => MonadResource (IdentityT m) | |
| MonadResource m => MonadResource (ContT r m) | |
| (Error e, MonadResource m) => MonadResource (ErrorT e m) | |
| MonadResource m => MonadResource (ReaderT r m) | |
| MonadResource m => MonadResource (StateT s m) | |
| MonadResource m => MonadResource (StateT s m) | |
| (Monoid w, MonadResource m) => MonadResource (WriterT w m) | |
| (Monoid w, MonadResource m) => MonadResource (WriterT w m) | |
| (Monoid w, MonadResource m) => MonadResource (RWST r w s m) | |
| (Monoid w, MonadResource m) => MonadResource (RWST r w s m) | 
runResourceT :: MonadBaseControl IO m => ResourceT m a -> m a
Unwrap a ResourceT transformer, and call all registered release actions. 
Note that there is some reference counting involved due to resourceForkIO. If multiple threads are sharing the same collection of resources, only the last call to runResourceT will deallocate the resources. 
Since 0.3.0
resourceForkIO :: MonadBaseControl IO m => ResourceT m () -> ResourceT m ThreadId
Introduce a reference-counting scheme to allow a resource context to be shared by multiple threads. Once the last thread exits, all remaining resources will be released.
Note that abuse of this function will greatly delay the deallocation of registered resources. This function should be used with care. A general guideline:
If you are allocating a resource that should be shared by multiple threads, and will be held for a long time, you should allocate it at the beginning of a new ResourceT block and then call resourceForkIO from there. 
Since 0.3.0