// Matrix Construct // // Copyright (C) Matrix Construct Developers, Authors & Contributors // Copyright (C) 2016-2018 Jason Volk // // 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. The // full license for this software is available in the LICENSE file. #pragma once #define HAVE_IRCD_DB_TXN_H namespace ircd::db { struct txn; using delta_closure = std::function; using delta_closure_bool = std::function; using seq_closure = std::function; using seq_closure_bool = std::function; bool for_each(const txn &, const delta_closure_bool &); void for_each(const txn &, const delta_closure &); bool for_each(database &d, const uint64_t &seq, const seq_closure_bool &); void for_each(database &d, const uint64_t &seq, const seq_closure &); void get(database &d, const uint64_t &seq, const seq_closure &); std::string debug(const txn &); } struct ircd::db::txn { struct opts; struct checkpoint; struct append; struct handler; enum state :uint8_t; using value_closure = std::function; database *d {nullptr}; std::unique_ptr wb; enum state state {0}; public: explicit operator const rocksdb::WriteBatch &() const; explicit operator const database &() const; explicit operator rocksdb::WriteBatch &(); explicit operator database &(); template T val(const op &, const string_view &col, const string_view &key, T def = {}) const; template T at(const op &, const string_view &col, const string_view &key) const; bool get(const op &, const string_view &col, const string_view &key, const value_closure &) const; void at(const op &, const string_view &col, const string_view &key, const value_closure &) const; bool has(const op &, const string_view &col, const string_view &key) const; bool get(const op &, const string_view &col, const delta_closure &) const; void at(const op &, const string_view &col, const delta_closure &) const; bool has(const op &, const string_view &col) const; bool has(const op &) const; size_t bytes() const; // size of data in txn. size_t size() const; // count of updates in txn. // commit void operator()(database &, const sopts & = {}); void operator()(const sopts & = {}); // clear void clear(); txn() = default; txn(database &); txn(database &, const opts &); txn(database &, std::unique_ptr &&); ~txn() noexcept; }; enum ircd::db::txn::state :uint8_t { BUILD = 0, COMMIT = 1, COMMITTED = 2, }; struct ircd::db::txn::append { append(txn &, database &, const delta &); append(txn &, column &, const column::delta &); append(txn &, const cell::delta &); append(txn &, const row::delta &); append(txn &, const delta &); append(txn &, const string_view &key, const json::iov &); }; struct ircd::db::txn::checkpoint { txn &t; checkpoint(txn &); ~checkpoint() noexcept; }; struct ircd::db::txn::opts { size_t reserve_bytes = 0; size_t max_bytes = 0; }; template T ircd::db::txn::at(const op &op, const string_view &col, const string_view &key) const { T ret; at(op, col, key, [&ret](const string_view &val) { ret = byte_view(val); }); return ret; } template T ircd::db::txn::val(const op &op, const string_view &col, const string_view &key, T ret) const { get(op, col, key, value_closure{[&ret](const string_view &val) { ret = byte_view(val); }}); return ret; }