// // 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. // // 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_TXN_H namespace ircd::db { struct txn; bool test(const txn &, const std::function &); bool until(const txn &, const std::function &); void for_each(const txn &, const std::function &); std::string debug(const txn &); } class ircd::db::txn { database *d {nullptr}; std::unique_ptr wb; public: struct opts; struct checkpoint; struct append; struct handler; explicit operator const rocksdb::WriteBatch &() const; explicit operator const database &() const; explicit operator rocksdb::WriteBatch &(); explicit operator database &(); string_view get(const op &, const string_view &col, const string_view &key) const; string_view at(const op &, const string_view &col, const string_view &key) const; bool has(const op &, const string_view &col, const string_view &key) const; delta get(const op &, const string_view &col) const; delta at(const op &, const string_view &col) const; bool has(const op &, const string_view &col) const; bool has(const op &) const; size_t bytes() const; size_t size() const; // commit void operator()(database &, const sopts & = {}); void operator()(const sopts & = {}); // clear void clear(); txn() = default; txn(database &); txn(database &, const opts &); ~txn() noexcept; }; 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 &); template append(txn &, const string_view &key, const json::tuple &); }; 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 ircd::db::txn::append::append(txn &txn, const string_view &key, const json::tuple &tuple) { for_each(tuple, [&txn, &key](const auto &col, auto&& val) { if(defined(val)) append { txn, delta { col, key, byte_view{val} } }; }); }