Move replica-oriented classes to the replica namespace. The main classes moved are ::database, ::keyspace, and ::table, but a few ancillary classes are also moved. There are certainly classes that should be moved but aren't (like distributed_loader) but we have to start somewhere. References are adjusted treewide. In many cases, it is obvious that a call site should not access the replica (but the data_dictionary instead), but that is left for separate work. scylla-gdb.py is adjusted to look for both the new and old names.
90 lines
3.3 KiB
C++
90 lines
3.3 KiB
C++
/*
|
|
* Copyright (C) 2021-present ScyllaDB
|
|
*/
|
|
|
|
/*
|
|
* This file is part of Scylla.
|
|
*
|
|
* Scylla is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Scylla is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with Scylla. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "data_dictionary.hh"
|
|
|
|
// Interface for implementing data_dictionary classes
|
|
|
|
namespace data_dictionary {
|
|
|
|
class impl {
|
|
public:
|
|
virtual ~impl();
|
|
virtual std::optional<keyspace> try_find_keyspace(database db, std::string_view name) const = 0;
|
|
virtual std::optional<table> try_find_table(database db, std::string_view ks, std::string_view tab) const = 0;
|
|
virtual std::optional<table> try_find_table(database db, utils::UUID id) const = 0;
|
|
virtual const secondary_index::secondary_index_manager& get_index_manager(table t) const = 0;
|
|
virtual schema_ptr get_table_schema(table t) const = 0;
|
|
virtual lw_shared_ptr<keyspace_metadata> get_keyspace_metadata(keyspace ks) const = 0;
|
|
virtual const locator::abstract_replication_strategy& get_replication_strategy(keyspace ks) const = 0;
|
|
virtual const std::vector<view_ptr>& get_table_views(table t) const = 0;
|
|
virtual sstring get_available_index_name(database db, std::string_view ks_name, std::string_view table_name,
|
|
std::optional<sstring> index_name_root) const = 0;
|
|
virtual std::set<sstring> existing_index_names(database db, std::string_view ks_name, std::string_view cf_to_exclude = {}) const = 0;
|
|
virtual schema_ptr find_indexed_table(database db, std::string_view ks_name, std::string_view index_name) const = 0;
|
|
virtual schema_ptr get_cdc_base_table(database db, const schema&) const = 0;
|
|
virtual const db::config& get_config(database db) const = 0;
|
|
virtual const db::extensions& get_extensions(database db) const = 0;
|
|
virtual const gms::feature_service& get_features(database db) const = 0;
|
|
virtual replica::database& real_database(database db) const = 0;
|
|
protected:
|
|
// Tools for type erasing an unerasing
|
|
static database make_database(const impl* i, const void* db) {
|
|
return database(i, db);
|
|
}
|
|
static keyspace make_keyspace(const impl* i, const void* k) {
|
|
return keyspace(i, k);
|
|
}
|
|
static table make_table(const impl* i, const void* db) {
|
|
return table(i, db);
|
|
}
|
|
static const void* extract(database db) {
|
|
return db._database;
|
|
}
|
|
static const void* extract(keyspace ks) {
|
|
return ks._keyspace;
|
|
}
|
|
static const void* extract(table t) {
|
|
return t._table;
|
|
}
|
|
};
|
|
|
|
inline
|
|
table::table(const impl* ops, const void* table)
|
|
: _ops(ops)
|
|
, _table(table) {
|
|
}
|
|
|
|
inline
|
|
keyspace::keyspace(const impl* ops, const void* keyspace)
|
|
: _ops(ops)
|
|
, _keyspace(keyspace) {
|
|
}
|
|
|
|
inline
|
|
database::database(const impl* ops, const void* database)
|
|
: _ops(ops)
|
|
, _database(database) {
|
|
}
|
|
|
|
} |