2018-01-18 03:34:20 +01:00
|
|
|
// 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-01-19 02:59:22 +01:00
|
|
|
// copyright notice and this permission notice is present in all copies. The
|
|
|
|
// full license for this software is available in the LICENSE file.
|
2018-01-18 03:34:20 +01:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#define HAVE_IRCD_DB_DATABASE_COMPARATOR_H
|
|
|
|
|
|
|
|
// This file is not part of the standard include stack because it requires
|
|
|
|
// RocksDB symbols which we cannot forward declare. It is used internally
|
|
|
|
// and does not need to be included by general users of IRCd.
|
|
|
|
|
|
|
|
struct ircd::db::database::comparator final
|
|
|
|
:rocksdb::Comparator
|
|
|
|
{
|
|
|
|
using Slice = rocksdb::Slice;
|
|
|
|
|
|
|
|
database *d;
|
|
|
|
db::comparator user;
|
|
|
|
|
2018-12-10 00:29:49 +01:00
|
|
|
bool CanKeysWithDifferentByteContentsBeEqual() const noexcept override;
|
2018-10-31 19:23:55 +01:00
|
|
|
bool IsSameLengthImmediateSuccessor(const Slice &s, const Slice &t) const noexcept override;
|
2018-01-18 09:49:23 +01:00
|
|
|
void FindShortestSeparator(std::string *start, const Slice &limit) const noexcept override;
|
|
|
|
void FindShortSuccessor(std::string *key) const noexcept override;
|
|
|
|
int Compare(const Slice &a, const Slice &b) const noexcept override;
|
|
|
|
bool Equal(const Slice &a, const Slice &b) const noexcept override;
|
|
|
|
const char *Name() const noexcept override;
|
2018-01-18 03:34:20 +01:00
|
|
|
|
2018-10-31 19:23:30 +01:00
|
|
|
comparator(database *const &d, db::comparator user);
|
2018-01-18 03:34:20 +01:00
|
|
|
};
|