Files
scylladb/sstables/sstable_version.cc
Botond Dénes 85f05fbe1b Revert "Merge 'Add digests for all sstable components in scylla metadata' from Taras Veretilnyk"
This reverts commit 866c96f536, reversing
changes made to 367633270a.

This change caused all longevities to fail, with a crash in parsing
scylla-metadata. The investigation is still ongoing, with no quick fix
in sight yet.

Fixes: #27496

Closes scylladb/scylladb#27518
2025-12-16 11:34:40 +02:00

105 lines
4.2 KiB
C++

/*
* Copyright (C) 2018-present ScyllaDB
*/
/*
* SPDX-License-Identifier: LicenseRef-ScyllaDB-Source-Available-1.0
*/
#include "version.hh"
#include "sstable_version.hh"
#include "sstable_version_k_l.hh"
#include "sstable_version_m.hh"
namespace sstables {
template <size_t S1, size_t S2>
constexpr bool check_sstable_versions(const std::array<sstable_version_types, S1>& all_sstable_versions,
const std::array<sstable_version_types, S2>& writable_sstable_versions, sstable_version_types oldest_writable_sstable_format) {
for (auto v : writable_sstable_versions) {
if (v < oldest_writable_sstable_format) {
return false;
}
}
size_t expected = 0;
for (auto v : all_sstable_versions) {
if (v >= oldest_writable_sstable_format) {
++expected;
}
}
return expected == S2;
}
static_assert(check_sstable_versions(all_sstable_versions, writable_sstable_versions, oldest_writable_sstable_format));
const sstring sstable_version_constants::TOC_SUFFIX = "TOC.txt";
const sstring sstable_version_constants::TEMPORARY_TOC_SUFFIX = "TOC.txt.tmp";
sstable_version_constants::component_map_t sstable_version_constants::create_component_map() {
return {
{ component_type::CompressionInfo, "CompressionInfo.db" },
{ component_type::Data, "Data.db" },
{ component_type::TOC, TOC_SUFFIX },
{ component_type::CRC, "CRC.db" },
{ component_type::Filter, "Filter.db" },
{ component_type::Statistics, "Statistics.db" },
{ component_type::Scylla, "Scylla.db" },
{ component_type::TemporaryTOC, TEMPORARY_TOC_SUFFIX },
{ component_type::TemporaryStatistics, "Statistics.db.tmp" }
};
}
const sstable_version_constants::component_map_t&
sstable_version_constants::get_component_map(sstable_version_types version) {
switch (version) {
case sstable_version_types::ka:
case sstable_version_types::la:
return sstable_version_constants_k_l::_component_map;
case sstable_version_types::mc:
case sstable_version_types::md:
case sstable_version_types::me:
return sstable_version_constants_m::_component_map;
case sstable_version_types::ms:
return sstable_version_constants_ms::_component_map;
}
// Should never reach this.
// Compiler should complain if the switch above does no cover all sstable_version_types values.
throw std::invalid_argument("Invalid sstable format version");
}
const sstable_version_constants::component_map_t sstable_version_constants_k_l::create_component_map() {
auto result = sstable_version_constants::create_component_map();
result.emplace(component_type::Index, "Index.db");
result.emplace(component_type::Summary, "Summary.db");
result.emplace(component_type::Digest, "Digest.sha1");
return result;
}
const sstable_version_constants::component_map_t sstable_version_constants_k_l::_component_map =
sstable_version_constants_k_l::create_component_map();
const sstable_version_constants::component_map_t sstable_version_constants_m::create_component_map() {
auto result = sstable_version_constants::create_component_map();
result.emplace(component_type::Index, "Index.db");
result.emplace(component_type::Summary, "Summary.db");
result.emplace(component_type::Digest, "Digest.crc32");
return result;
}
const sstable_version_constants::component_map_t sstable_version_constants_m::_component_map =
sstable_version_constants_m::create_component_map();
const sstable_version_constants::component_map_t sstable_version_constants_ms::create_component_map() {
auto result = sstable_version_constants_m::create_component_map();
// Note: for `ms`, we inherit all components from `me`.
// This means that we allow `ms` to have Index.db and Summary.db components.
result.emplace(component_type::Rows, "Rows.db");
result.emplace(component_type::Partitions, "Partitions.db");
result.emplace(component_type::TemporaryHashes, "TemporaryHashes.db.tmp");
return result;
}
const sstable_version_constants::component_map_t sstable_version_constants_ms::_component_map =
sstable_version_constants_ms::create_component_map();
}