0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-22 12:30:00 +01:00
construct/include/ircd/db/index.h

100 lines
3.1 KiB
C
Raw Normal View History

// Matrix Construct
//
// Copyright (C) Matrix Construct Developers, Authors & Contributors
// Copyright (C) 2016-2018 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
2018-02-03 18:22:01 -08:00
// copyright notice and this permission notice is present in all copies. The
// full license for this software is available in the LICENSE file.
2017-09-08 02:02:47 -07:00
#pragma once
#define HAVE_IRCD_DB_INDEX_H
namespace ircd::db
{
struct index;
}
2017-09-27 18:24:55 -07:00
/// An index is a glorified column; the database descriptor for this column
/// must specify a prefix-extractor otherwise this index just behaves like
/// a regular key/value column. Index is used to create iterable domains of
/// a column which all share the same key-prefix.
///
/// The index allows a concatenation of two strings to form a key. This con-
/// catenated key is still unique for the column as a whole and is stored as
/// the full concatenation -- however, as stated above the prefix function must
/// be aware of how such a concatenation can be separated back into two
/// strings.
///
/// db::index allows the user to query for either just the first string, or
/// the whole concatenation. In either case, the resulting iterator can move
/// only around the keys and values within the domain of that first string.
/// The iterator presents the user with it.first = second string only, thereby
/// hiding the prefix allowing for easier iteration of the domain.
///
/// Index is not good at reverse iteration due to limitations in RocksDB. Thus
/// it's better to just flip the comparator function for the column.
///
2017-09-08 02:02:47 -07:00
struct ircd::db::index
:column
{
2017-09-22 03:31:44 -07:00
struct const_iterator_base;
2017-09-08 02:02:47 -07:00
struct const_iterator;
2017-09-22 03:31:44 -07:00
struct const_reverse_iterator;
2017-09-08 02:02:47 -07:00
using iterator_type = const_iterator;
using const_iterator_type = const_iterator;
static const gopts applied_opts;
2017-09-22 03:31:44 -07:00
const_iterator end(const string_view &key, gopts = {});
const_iterator begin(const string_view &key, gopts = {});
const_reverse_iterator rend(const string_view &key, gopts = {});
const_reverse_iterator rbegin(const string_view &key, gopts = {});
2017-09-08 02:02:47 -07:00
using column::column;
};
namespace ircd::db
{
bool seek(index::const_iterator_base &, const string_view &);
bool seek(index::const_iterator_base &, const pos &);
}
2017-09-22 03:31:44 -07:00
struct ircd::db::index::const_iterator_base
:ircd::db::column::const_iterator_base
2017-09-08 02:02:47 -07:00
{
friend class index;
2017-09-08 02:02:47 -07:00
const value_type &operator*() const;
const value_type *operator->() const;
2017-09-22 03:31:44 -07:00
using column::const_iterator_base::const_iterator_base;
friend bool seek(index::const_iterator_base &, const string_view &);
friend bool seek(index::const_iterator_base &, const pos &);
2017-09-22 03:31:44 -07:00
};
struct ircd::db::index::const_iterator
:ircd::db::index::const_iterator_base
{
friend class index;
const_iterator &operator++();
const_iterator &operator--();
2017-09-22 03:31:44 -07:00
using index::const_iterator_base::const_iterator_base;
};
struct ircd::db::index::const_reverse_iterator
:ircd::db::index::const_iterator_base
{
friend class index;
const_reverse_iterator &operator++();
const_reverse_iterator &operator--();
2017-09-22 03:31:44 -07:00
using index::const_iterator_base::const_iterator_base;
2017-09-08 02:02:47 -07:00
};