mirror of
https://github.com/facebook/rocksdb.git
synced 2024-11-26 16:30:56 +00:00
bafce61979
Summary: First commit for rdb shell Test Plan: unit_test.js does simple assertions on most of the main functionality; will update with rest of tests Reviewers: igor, rven, lijn, yhciang, sdong Subscribers: dhruba, leveldb Differential Revision: https://reviews.facebook.net/D28749
59 lines
2 KiB
C++
59 lines
2 KiB
C++
#ifndef DBWRAPPER_H
|
|
#define DBWRAPPER_H
|
|
|
|
#include <map>
|
|
#include <node.h>
|
|
|
|
#include "rocksdb/db.h"
|
|
#include "rocksdb/slice.h"
|
|
#include "rocksdb/options.h"
|
|
|
|
using namespace v8;
|
|
|
|
// Used to encapsulate a particular instance of an opened database.
|
|
//
|
|
// This object should not be used directly in C++; it exists solely to provide
|
|
// a mapping from a JavaScript object to a C++ code that can use the RocksDB
|
|
// API.
|
|
class DBWrapper : public node::ObjectWrap {
|
|
public:
|
|
static void Init(Handle<Object> exports);
|
|
|
|
private:
|
|
explicit DBWrapper();
|
|
~DBWrapper();
|
|
|
|
// Helper methods
|
|
static bool HasFamilyNamed(std::string& name, DBWrapper* db);
|
|
static bool AddToBatch(rocksdb::WriteBatch& batch, bool del,
|
|
Handle<Array> array);
|
|
static bool AddToBatch(rocksdb::WriteBatch& batch, bool del,
|
|
Handle<Array> array, DBWrapper* db_wrapper, std::string cf);
|
|
static Handle<Value> CompactRangeDefault(const v8::Arguments& args);
|
|
static Handle<Value> CompactColumnFamily(const Arguments& args);
|
|
static Handle<Value> CompactOptions(const Arguments& args);
|
|
static Handle<Value> CompactAll(const Arguments& args);
|
|
|
|
// C++ mappings of API methods
|
|
static Persistent<v8::Function> constructor;
|
|
static Handle<Value> Open(const Arguments& args);
|
|
static Handle<Value> New(const Arguments& args);
|
|
static Handle<Value> Get(const Arguments& args);
|
|
static Handle<Value> Put(const Arguments& args);
|
|
static Handle<Value> Delete(const Arguments& args);
|
|
static Handle<Value> Dump(const Arguments& args);
|
|
static Handle<Value> WriteBatch(const Arguments& args);
|
|
static Handle<Value> CreateColumnFamily(const Arguments& args);
|
|
static Handle<Value> CompactRange(const Arguments& args);
|
|
static Handle<Value> Close(const Arguments& args);
|
|
|
|
// Internal fields
|
|
rocksdb::Options options_;
|
|
rocksdb::Status status_;
|
|
rocksdb::DB* db_;
|
|
std::unordered_map<std::string, rocksdb::ColumnFamilyHandle*>
|
|
columnFamilies_;
|
|
};
|
|
|
|
#endif
|