GitXplorerGitXplorer
g

rcppleveldb

public
7 stars
1 forks
1 issues

Commits

List of commits on branch master.
Unverified
0c3907513f45ef20368ff88fef25170c03af761f

Update authors list

committed 9 years ago
Unverified
72e6b7c744735b0c6bc3f571bafe545442ee0f58

Merge pull request #1 from gabeiscoding/master

ggokceneraslan committed 9 years ago
Unverified
569ccdbeeb826e02221c3e1313d9818057c63d4a

Added basic LevelDB iteration support

ggaberudy committed 9 years ago
Unverified
ffc9e31e407a8dd576361d9d710df90d2b1b22d7

Fix plyvel URL

committed 9 years ago
Unverified
c5f6974309766a003586ace1ad774f52ba87ec3b

Add a TODO list

committed 9 years ago
Unverified
475af81874d47ddd6638e2e4c2802272a2e445fa

Copy-paste friendly snippet in Readme file

committed 9 years ago

README

The README file for this repository.

RcppLevelDB License

RcppLevelDB is a Rcpp based LevelDB binding for R

Dependencies

Getting Started

library(RcppLevelDB)

ldb <- new(LevelDB, 'my-leveldb') #creates the DB, if not exists

ldb$Put('key1', list(a=c(1,2,3), b='sometext', c=42))
#>[1] TRUE
ldb$Put('anotherkey', 'somevalue')
#>[1] TRUE

#vectorized Get & Delete operations
ldb$Get(c('key1', 'anotherkey'))
#>[[1]]
#>[[1]]$a
#>[1] 1 2 3
#>
#>[[1]]$b
#>[1] "sometext"
#>
#>[[1]]$c
#>[1] 42
#>
#>
#>[[2]]
#>[1] "somevalue"
#>

#Iteration
ldb$StartIteration()
#>[1] TRUE
ldb$IterNext()
#>[[1]]
#>[1] "anotherkey"
#>
#>[[2]]
#>[1] "somevalue"
#>
> ldb$IterNext()
#>[[1]]
#>[1] "key1"
#>
#>[[2]]
#>[[2]]$a
#>[1] 1 2 3
#>
#>[[2]]$b
#>[1] "sometext"
#>
#>[[2]]$c
#>[1] 42
#>
ldb$IterNext()
#>[[1]]
#>[1] NA
#>
#> 

#Deletion
ldb$Delete(c('key1', 'anotherkey'))
#>[1] TRUE TRUE
ldb$Get(c('key1', 'anotherkey'))
#>[[1]]
#>[1] NA
#>
#>[[2]]
#>[1] NA
#>
rm(ldb) #to close the database safely
gc() # remove all handles

TODO

  • Expose Options/ReadOptions/WriteOptions structs to R
  • Add default arguments to constructor and Put/Get/Delete methods e.g. create_if_missing=TRUE, sync=FALSE etc.
  • Add support for BloomFilter policies, WriteBatch, and Iterators
  • Add RepairDB and DestroyDB functions
  • Something like Structured Get operation: create a data.frame out of values of the given query keys, when the values have a pre-defined structure
  • plyvel is a nice leveldb binding example to get some influence regarding new features

Authors

Gökcen Eraslan, based on RcppRedis by Dirk Eddelbuettel

Support for iterators was added by Gabe Rudy.

License

GPL (>= 2)