mirror of
https://github.com/XRPLF/rippled.git
synced 2025-11-19 18:45:52 +00:00
Add MDB NodeStore::BackendFactory
This commit is contained in:
@@ -77,6 +77,7 @@ SOURCES += \
|
||||
../../modules/ripple_data/ripple_data.cpp \
|
||||
../../modules/ripple_json/ripple_json.cpp \
|
||||
../../modules/ripple_leveldb/ripple_leveldb.cpp \
|
||||
../../modules/ripple_mdb/ripple_mdb.c \
|
||||
../../modules/ripple_net/ripple_net.cpp \
|
||||
../../modules/ripple_sqlite/ripple_sqlite.c \
|
||||
../../modules/ripple_websocket/ripple_websocket.cpp
|
||||
|
||||
@@ -135,6 +135,7 @@ COMPILED_FILES = [
|
||||
'modules/ripple_data/ripple_data.cpp',
|
||||
'modules/ripple_json/ripple_json.cpp',
|
||||
'modules/ripple_leveldb/ripple_leveldb.cpp',
|
||||
'modules/ripple_mdb/ripple_mdb.c',
|
||||
'modules/ripple_net/ripple_net.cpp',
|
||||
'modules/ripple_websocket/ripple_websocket.cpp',
|
||||
'modules/ripple_sqlite/ripple_sqlite.c'
|
||||
|
||||
133
modules/ripple_app/node/ripple_MdbBackendFactory.cpp
Normal file
133
modules/ripple_app/node/ripple_MdbBackendFactory.cpp
Normal file
@@ -0,0 +1,133 @@
|
||||
//------------------------------------------------------------------------------
|
||||
/*
|
||||
Copyright (c) 2011-2013, OpenCoin, Inc.
|
||||
*/
|
||||
//==============================================================================
|
||||
|
||||
class MdbBackendFactory::Backend : public NodeStore::Backend
|
||||
{
|
||||
public:
|
||||
explicit Backend (StringPairArray const& keyValues)
|
||||
: m_env (nullptr)
|
||||
{
|
||||
if (keyValues ["path"].isEmpty ())
|
||||
throw std::runtime_error ("Missing path in MDB backend");
|
||||
|
||||
int error = 0;
|
||||
|
||||
error = mdb_env_create (&m_env);
|
||||
|
||||
if (error == 0)
|
||||
{
|
||||
error = mdb_env_open (
|
||||
m_env,
|
||||
keyValues ["path"].toStdString().c_str (),
|
||||
0,
|
||||
0);
|
||||
|
||||
}
|
||||
|
||||
if (error != 0)
|
||||
{
|
||||
String s;
|
||||
s << "Error #" << error << " creating mdb environment";
|
||||
throw std::runtime_error (s.toStdString ());
|
||||
}
|
||||
}
|
||||
|
||||
~Backend ()
|
||||
{
|
||||
if (m_env != nullptr)
|
||||
mdb_env_close (m_env);
|
||||
}
|
||||
|
||||
std::string getDataBaseName()
|
||||
{
|
||||
return std::string ();
|
||||
}
|
||||
|
||||
bool store (NodeObject::ref obj)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
bool bulkStore (std::vector <NodeObject::pointer> const& objs)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
NodeObject::pointer retrieve (uint256 const& hash)
|
||||
{
|
||||
return NodeObject::pointer ();
|
||||
}
|
||||
|
||||
void visitAll (FUNCTION_TYPE <void (NodeObject::pointer)> func)
|
||||
{
|
||||
}
|
||||
|
||||
Blob toBlob (NodeObject::ref obj) const
|
||||
{
|
||||
Blob rawData (9 + obj->getData ().size ());
|
||||
unsigned char* bufPtr = &rawData.front();
|
||||
|
||||
*reinterpret_cast <uint32*> (bufPtr + 0) = ntohl (obj->getIndex ());
|
||||
|
||||
*reinterpret_cast <uint32*> (bufPtr + 4) = ntohl (obj->getIndex ());
|
||||
|
||||
*(bufPtr + 8) = static_cast <unsigned char> (obj->getType ());
|
||||
|
||||
memcpy (bufPtr + 9, &obj->getData ().front (), obj->getData ().size ());
|
||||
|
||||
return rawData;
|
||||
}
|
||||
|
||||
NodeObject::pointer fromBinary (uint256 const& hash, char const* data, int size) const
|
||||
{
|
||||
if (size < 9)
|
||||
throw std::runtime_error ("undersized object");
|
||||
|
||||
uint32 const index = htonl (*reinterpret_cast <uint32 const*> (data));
|
||||
|
||||
int const htype = data [8];
|
||||
|
||||
return boost::make_shared <NodeObject> (
|
||||
static_cast <NodeObjectType> (htype),
|
||||
index,
|
||||
data + 9,
|
||||
size - 9,
|
||||
hash);
|
||||
}
|
||||
|
||||
private:
|
||||
MDB_env* m_env;
|
||||
};
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
|
||||
MdbBackendFactory::MdbBackendFactory ()
|
||||
{
|
||||
}
|
||||
|
||||
MdbBackendFactory::~MdbBackendFactory ()
|
||||
{
|
||||
}
|
||||
|
||||
MdbBackendFactory& MdbBackendFactory::getInstance ()
|
||||
{
|
||||
static MdbBackendFactory instance;
|
||||
|
||||
return instance;
|
||||
}
|
||||
|
||||
String MdbBackendFactory::getName () const
|
||||
{
|
||||
return "mdb";
|
||||
}
|
||||
|
||||
NodeStore::Backend* MdbBackendFactory::createInstance (StringPairArray const& keyValues)
|
||||
{
|
||||
return new MdbBackendFactory::Backend (keyValues);
|
||||
}
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
|
||||
29
modules/ripple_app/node/ripple_MdbBackendFactory.h
Normal file
29
modules/ripple_app/node/ripple_MdbBackendFactory.h
Normal file
@@ -0,0 +1,29 @@
|
||||
//------------------------------------------------------------------------------
|
||||
/*
|
||||
Copyright (c) 2011-2013, OpenCoin, Inc.
|
||||
*/
|
||||
//==============================================================================
|
||||
|
||||
#ifndef RIPPLE_MDBBACKENDFACTORY_H_INCLUDED
|
||||
#define RIPPLE_MDBBACKENDFACTORY_H_INCLUDED
|
||||
|
||||
/** Factory to produce a backend using MDB.
|
||||
|
||||
@note MDB is not currently available for Win32
|
||||
*/
|
||||
class MdbBackendFactory : public NodeStore::BackendFactory
|
||||
{
|
||||
private:
|
||||
class Backend;
|
||||
|
||||
MdbBackendFactory ();
|
||||
~MdbBackendFactory ();
|
||||
|
||||
public:
|
||||
static MdbBackendFactory& getInstance ();
|
||||
|
||||
String getName () const;
|
||||
NodeStore::Backend* createInstance (StringPairArray const& keyValues);
|
||||
};
|
||||
|
||||
#endif
|
||||
@@ -74,7 +74,7 @@
|
||||
#include "ripple_app.h"
|
||||
|
||||
#include "../ripple_data/ripple_data.h"
|
||||
|
||||
#include "../ripple_mdb/ripple_mdb.h"
|
||||
#include "../ripple_net/ripple_net.h"
|
||||
|
||||
#include "../modules/ripple_websocket/ripple_websocket.h"
|
||||
@@ -97,6 +97,7 @@ namespace ripple
|
||||
#include "node/ripple_NodeObject.h"
|
||||
#include "node/ripple_NodeStore.h"
|
||||
#include "node/ripple_LevelDBBackendFactory.h"
|
||||
#include "node/ripple_MdbBackendFactory.h"
|
||||
#include "node/ripple_NullBackendFactory.h"
|
||||
#include "node/ripple_SqliteBackendFactory.h"
|
||||
|
||||
@@ -238,6 +239,7 @@ static const uint64 tenTo17m1 = tenTo17 - 1;
|
||||
#include "node/ripple_NodeObject.cpp"
|
||||
#include "node/ripple_NodeStore.cpp"
|
||||
#include "node/ripple_LevelDBBackendFactory.cpp"
|
||||
#include "node/ripple_MdbBackendFactory.cpp"
|
||||
#include "node/ripple_NullBackendFactory.cpp"
|
||||
#include "node/ripple_SqliteBackendFactory.cpp"
|
||||
|
||||
|
||||
@@ -12,27 +12,9 @@
|
||||
|
||||
#include "beast/modules/beast_core/system/beast_TargetPlatform.h"
|
||||
|
||||
#define __LITTLE_ENDIAN 1
|
||||
#define __BIG_ENDIAN 2
|
||||
typedef unsigned short uint16_t;
|
||||
|
||||
#if BEAST_LITTLE_ENDIAN
|
||||
# define BYTE_ORDER __LITTLE_ENDIAN
|
||||
#elif BEAST_BIG_ENDIAN
|
||||
# define BYTE_ORDER __BIG_ENDIAN
|
||||
#else
|
||||
# error "Unknown endianness"
|
||||
#endif
|
||||
|
||||
#if BEAST_MSVC
|
||||
#pragma warning (push)
|
||||
//#pragma warning (disable: 4092)
|
||||
#endif
|
||||
#if RIPPLE_MDB_AVAILABLE
|
||||
|
||||
#include "mdb/libraries/liblmdb/mdb.c"
|
||||
#include "mdb/libraries/liblmdb/midl.c"
|
||||
#include "mdb/libraries/liblmdb/mdb.c"
|
||||
|
||||
#if BEAST_MSVC
|
||||
#pragma warning (pop)
|
||||
#endif
|
||||
|
||||
@@ -7,5 +7,15 @@
|
||||
#ifndef RIPPLE_MDB_H_INCLUDED
|
||||
#define RIPPLE_MDB_H_INCLUDED
|
||||
|
||||
#if ! BEAST_WIN32
|
||||
#define RIPPLE_MDB_AVAILABLE 1
|
||||
|
||||
#include "mdb/libraries/liblmdb/lmdb.h"
|
||||
|
||||
#else
|
||||
// mdb is unsupported on Win32
|
||||
#define RIPPLE_MDB_AVAILBLE 0
|
||||
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
@@ -184,7 +184,9 @@ int rippleMain (int argc, char** argv)
|
||||
// These must be added before the Application object is created
|
||||
NodeStore::addBackendFactory (SqliteBackendFactory::getInstance ());
|
||||
NodeStore::addBackendFactory (LevelDBBackendFactory::getInstance ());
|
||||
|
||||
#if RIPPLE_MDB_AVAILABLE
|
||||
NodeStore::addBackendFactory (MdbBackendFactory::getInstance ());
|
||||
#endif
|
||||
|
||||
if (! RandomNumbers::getInstance ().initialize ())
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user