/* * Copyright (C) 2015-present ScyllaDB */ /* * SPDX-License-Identifier: AGPL-3.0-or-later */ #pragma once // Not part of atomic_cell.hh to avoid cyclic dependency between types.hh and atomic_cell.hh #include "types.hh" #include "types/collection.hh" #include "atomic_cell.hh" #include "atomic_cell_or_collection.hh" #include "hashing.hh" #include "counters.hh" template<> struct appending_hash { template void operator()(Hasher& h, collection_mutation_view cell, const column_definition& cdef) const { cell.with_deserialized(*cdef.type, [&] (collection_mutation_view_description m_view) { ::feed_hash(h, m_view.tomb); for (auto&& key_and_value : m_view.cells) { ::feed_hash(h, key_and_value.first); ::feed_hash(h, key_and_value.second, cdef); } }); } }; template<> struct appending_hash { template void operator()(Hasher& h, atomic_cell_view cell, const column_definition& cdef) const { feed_hash(h, cell.is_live()); feed_hash(h, cell.timestamp()); if (cell.is_live()) { if (cdef.is_counter()) { ::feed_hash(h, counter_cell_view(cell)); return; } if (cell.is_live_and_has_ttl()) { feed_hash(h, cell.expiry()); feed_hash(h, cell.ttl()); } feed_hash(h, cell.value()); } else { feed_hash(h, cell.deletion_time()); } } }; template<> struct appending_hash { template void operator()(Hasher& h, const atomic_cell& cell, const column_definition& cdef) const { feed_hash(h, static_cast(cell), cdef); } }; template<> struct appending_hash { template void operator()(Hasher& h, const collection_mutation& cm, const column_definition& cdef) const { feed_hash(h, static_cast(cm), cdef); } }; template<> struct appending_hash { template void operator()(Hasher& h, const atomic_cell_or_collection& c, const column_definition& cdef) const { if (cdef.is_atomic()) { feed_hash(h, c.as_atomic_cell(cdef), cdef); } else { feed_hash(h, c.as_collection_mutation(), cdef); } } };