/* * Copyright (C) 2015-present ScyllaDB */ /* * SPDX-License-Identifier: AGPL-3.0-or-later */ #pragma once #include #include #include using cql_protocol_version_type = uint8_t; // Abstraction of transport protocol-dependent serialization format // Protocols v1, v2 used 16 bits for collection sizes, while v3 and // above use 32 bits. But letting every bit of the code know what // transport protocol we're using (and in some cases, we aren't using // any transport -- it's for internal storage) is bad, so abstract it // away here. class cql_serialization_format { cql_protocol_version_type _version; public: static constexpr cql_protocol_version_type latest_version = 4; explicit cql_serialization_format(cql_protocol_version_type version) : _version(version) {} static cql_serialization_format latest() { return cql_serialization_format{latest_version}; } cql_protocol_version_type protocol_version() const { return _version; } void ensure_supported() const { if (_version < 3) { throw std::runtime_error("cql protocol version must be 3 or later"); } } };