2016-09-24 06:01:57 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 Charybdis Development Team
|
|
|
|
* Copyright (C) 2016 Jason Volk <jason@zemos.net>
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
|
|
* copyright notice and this permission notice is present in all copies.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
* DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
|
|
|
|
* INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
|
|
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#define HAVE_IRCD_DB_H
|
|
|
|
|
2017-03-31 00:57:08 +02:00
|
|
|
// IRCd Database
|
|
|
|
//
|
|
|
|
// Please see db/README.md for documentation.
|
|
|
|
//
|
2016-09-24 06:01:57 +02:00
|
|
|
namespace ircd {
|
|
|
|
namespace db {
|
|
|
|
|
2017-04-03 06:02:32 +02:00
|
|
|
struct cell;
|
|
|
|
struct row;
|
|
|
|
struct column;
|
|
|
|
struct database;
|
|
|
|
|
2017-03-31 00:57:08 +02:00
|
|
|
// Errors for the database subsystem. The exceptions that use _HIDENAME
|
|
|
|
// are built from RocksDB errors which already have an info string with
|
|
|
|
// an included name.
|
|
|
|
//
|
2016-09-24 06:01:57 +02:00
|
|
|
IRCD_EXCEPTION(ircd::error, error)
|
|
|
|
IRCD_EXCEPTION(error, not_found)
|
2017-03-31 00:57:08 +02:00
|
|
|
IRCD_EXCEPTION_HIDENAME(error, corruption)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, not_supported)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, invalid_argument)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, io_error)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, merge_in_progress)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, incomplete)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, shutdown_in_progress)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, timed_out)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, aborted)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, busy)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, expired)
|
|
|
|
IRCD_EXCEPTION_HIDENAME(error, try_again)
|
|
|
|
|
|
|
|
// db subsystem has its own logging facility
|
|
|
|
extern struct log::log log;
|
2017-03-24 02:36:49 +01:00
|
|
|
|
2017-03-31 00:57:08 +02:00
|
|
|
} // namespace db
|
|
|
|
} // namespace ircd
|
2016-09-24 06:01:57 +02:00
|
|
|
|
2017-04-03 06:02:32 +02:00
|
|
|
//
|
2017-03-31 00:57:08 +02:00
|
|
|
// These are forward declarations to objects we may carry a pointer to.
|
|
|
|
// Users of ircd::db should not be dealing with these types.
|
2017-04-03 06:02:32 +02:00
|
|
|
//
|
2017-03-31 00:57:08 +02:00
|
|
|
namespace rocksdb
|
2017-03-14 19:39:26 +01:00
|
|
|
{
|
2017-03-31 00:57:08 +02:00
|
|
|
struct DB;
|
2017-04-03 06:02:32 +02:00
|
|
|
struct Slice;
|
2017-03-31 00:57:08 +02:00
|
|
|
struct Options;
|
|
|
|
struct DBOptions;
|
|
|
|
struct ColumnFamilyOptions;
|
|
|
|
struct PlainTableOptions;
|
|
|
|
struct BlockBasedTableOptions;
|
|
|
|
struct Cache;
|
|
|
|
struct Iterator;
|
|
|
|
struct ColumnFamilyHandle;
|
|
|
|
struct Snapshot;
|
|
|
|
}
|
2017-03-14 19:39:26 +01:00
|
|
|
|
2017-04-03 06:02:32 +02:00
|
|
|
//
|
|
|
|
// Misc utils
|
|
|
|
//
|
2017-03-31 00:57:08 +02:00
|
|
|
namespace ircd {
|
|
|
|
namespace db {
|
2016-09-24 06:01:57 +02:00
|
|
|
|
2017-08-23 23:37:06 +02:00
|
|
|
extern const char *const version;
|
|
|
|
|
2017-04-03 06:02:32 +02:00
|
|
|
rocksdb::Slice slice(const string_view &);
|
|
|
|
string_view slice(const rocksdb::Slice &);
|
|
|
|
|
|
|
|
bool valid(const rocksdb::Iterator &);
|
|
|
|
string_view key(const rocksdb::Iterator &);
|
|
|
|
string_view val(const rocksdb::Iterator &);
|
|
|
|
|
2017-03-31 00:57:08 +02:00
|
|
|
std::string path(const std::string &name);
|
|
|
|
std::vector<std::string> available();
|
2016-09-25 03:25:57 +02:00
|
|
|
|
2017-04-03 06:02:32 +02:00
|
|
|
void log_rdb_perf_context(const bool &all = true);
|
|
|
|
|
2016-09-24 06:01:57 +02:00
|
|
|
} // namespace db
|
|
|
|
} // namespace ircd
|
2016-09-25 03:18:54 +02:00
|
|
|
|
2017-04-03 06:02:32 +02:00
|
|
|
#include "db/delta.h"
|
|
|
|
#include "db/database.h"
|
|
|
|
#include "db/opts.h"
|
|
|
|
#include "db/column.h"
|
|
|
|
#include "db/cell.h"
|
|
|
|
#include "db/row.h"
|
|
|
|
|
2017-03-23 22:58:24 +01:00
|
|
|
namespace ircd {
|
|
|
|
namespace db {
|
|
|
|
|
|
|
|
std::string merge_operator(const string_view &, const std::pair<string_view, string_view> &);
|
|
|
|
|
|
|
|
} // namespace db
|
|
|
|
} // namespace ircd
|
2017-04-03 06:02:32 +02:00
|
|
|
|
|
|
|
namespace ircd {
|
|
|
|
|
|
|
|
using database = db::database;
|
|
|
|
|
|
|
|
} // namespace ircd
|