/* * Copyright 2015-present ScyllaDB */ /* * SPDX-License-Identifier: LicenseRef-ScyllaDB-Source-Available-1.0 */ #include "frozen_schema.hh" #include "db/schema_tables.hh" #include "db/view/view.hh" #include "mutation/canonical_mutation.hh" #include "schema_mutations.hh" #include "idl/frozen_schema.dist.hh" #include "idl/frozen_schema.dist.impl.hh" frozen_schema::frozen_schema(const schema_ptr& s) : _data([&s] { schema_mutations sm = db::schema_tables::make_schema_mutations(s, api::new_timestamp(), true); bytes_ostream out; ser::writer_of_schema wr(out); std::move(wr).write_version(s->version()) .write_mutations(sm) .end_schema(); return out; }()) { } schema_ptr frozen_schema::unfreeze(const db::schema_ctxt& ctxt, std::optional base_info) const { auto in = ser::as_input_stream(_data); auto sv = ser::deserialize(in, std::type_identity()); auto sm = sv.mutations(); if (sm.is_view()) { return db::schema_tables::create_view_from_mutations(ctxt, std::move(sm), std::move(base_info), sv.version()); } else { if (base_info) { throw std::runtime_error("Trying to unfreeze regular table schema with base info"); } return db::schema_tables::create_table_from_mutations(ctxt, std::move(sm), sv.version()); } } frozen_schema::frozen_schema(bytes_ostream b) : _data(std::move(b)) { } const bytes_ostream& frozen_schema::representation() const { return _data; }