/* * Copyright 2015 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 . */ #pragma once #include #include "mutation.hh" #include "schema.hh" #include "canonical_mutation.hh" // Commutative representation of table schema // Equality ignores tombstones. class schema_mutations { mutation _columnfamilies; mutation _columns; mutation_opt _view_virtual_columns; mutation_opt _indices; mutation_opt _dropped_columns; mutation_opt _scylla_tables; public: schema_mutations(mutation columnfamilies, mutation columns, mutation_opt view_virtual_columns, mutation_opt indices, mutation_opt dropped_columns, mutation_opt scylla_tables) : _columnfamilies(std::move(columnfamilies)) , _columns(std::move(columns)) , _view_virtual_columns(std::move(view_virtual_columns)) , _indices(std::move(indices)) , _dropped_columns(std::move(dropped_columns)) , _scylla_tables(std::move(scylla_tables)) { } schema_mutations(canonical_mutation columnfamilies, canonical_mutation columns, bool is_view, std::optional indices, std::optional dropped_columns, std::optional scylla_tables, std::optional view_virtual_columns); schema_mutations(schema_mutations&&) = default; schema_mutations& operator=(schema_mutations&&) = default; schema_mutations(const schema_mutations&) = default; schema_mutations& operator=(const schema_mutations&) = default; void copy_to(std::vector& dst) const; const mutation& columnfamilies_mutation() const { return _columnfamilies; } const mutation& columns_mutation() const { return _columns; } const mutation_opt& view_virtual_columns_mutation() const { return _view_virtual_columns; } const mutation_opt& scylla_tables() const { return _scylla_tables; } mutation_opt& scylla_tables() { return _scylla_tables; } const mutation_opt& indices_mutation() const { return _indices; } const mutation_opt& dropped_columns_mutation() const { return _dropped_columns; } canonical_mutation columnfamilies_canonical_mutation() const { return canonical_mutation(_columnfamilies); } canonical_mutation columns_canonical_mutation() const { return canonical_mutation(_columns); } std::optional view_virtual_columns_canonical_mutation() const { if (_view_virtual_columns) { return canonical_mutation(*_view_virtual_columns); } return {}; } std::optional indices_canonical_mutation() const { if (_indices) { return canonical_mutation(*_indices); } return {}; } std::optional dropped_columns_canonical_mutation() const { if (_dropped_columns) { return canonical_mutation(*_dropped_columns); } return {}; } std::optional scylla_tables_canonical_mutation() const { if (_scylla_tables) { return canonical_mutation(*_scylla_tables); } return {}; } bool is_view() const; table_schema_version digest() const; bool operator==(const schema_mutations&) const; bool operator!=(const schema_mutations&) const; // Returns true iff any mutations contain any live cells bool live() const; friend std::ostream& operator<<(std::ostream&, const schema_mutations&); };