/* * Copyright (C) 2021-present 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 namespace utils { // Given type T and an std::variant Variant, return std::true_type if T is a variant element // This is also the recursion base case (empty variant), so return false. template struct is_variant_element : std::false_type { }; // Match - return true template struct is_variant_element> : std::true_type { }; // No match - recurse template struct is_variant_element> : is_variant_element> { }; // Givent type T and std::variant, true if T is one of the variant elements. template concept VariantElement = is_variant_element::value; }