Files
scylladb/replica/exceptions.hh
Kefu Chai 3f0fbdcd86 replica: do not include unused headers
these unused includes were identified by clangd. see
https://clangd.llvm.org/guides/include-cleaner#unused-include-warning
for more details on the "Unused include" warning.

Signed-off-by: Kefu Chai <kefu.chai@scylladb.com>

Closes scylladb/scylladb#16810
2024-01-17 09:27:09 +02:00

99 lines
2.6 KiB
C++

/*
* Copyright 2022-present ScyllaDB
*/
/*
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
#pragma once
#include <cstdint>
#include <exception>
#include <variant>
#include <seastar/core/abort_source.hh>
#include <seastar/core/print.hh>
#include <seastar/core/sstring.hh>
#include <seastar/core/timed_out_error.hh>
namespace replica {
// A marker indicating that the exception_variant holds an unknown exception.
// For example, replica sends a new type of error and coordinator does not
// understand it because it wasn't upgraded to a newer version yet.
struct unknown_exception {};
// A marker indicating that the exception variant doesn't hold any exception.
struct no_exception {};
class replica_exception : public std::exception {
public:
replica_exception() noexcept {};
};
class rate_limit_exception final : public replica_exception {
public:
rate_limit_exception() noexcept
: replica_exception()
{ }
virtual const char* what() const noexcept override { return "rate limit exceeded"; }
};
class stale_topology_exception final : public replica_exception {
int64_t _caller_version;
int64_t _callee_fence_version;
seastar::sstring _message;
public:
stale_topology_exception(int64_t caller_version, int64_t callee_fence_version)
: _caller_version(caller_version)
, _callee_fence_version(callee_fence_version)
, _message(seastar::format("stale topology exception, caller version {}, callee fence version {}", caller_version, callee_fence_version))
{
}
int64_t caller_version() const {
return _caller_version;
}
int64_t callee_fence_version() const {
return _callee_fence_version;
}
virtual const char* what() const noexcept override { return _message.c_str(); }
};
using abort_requested_exception = seastar::abort_requested_exception;
struct exception_variant {
std::variant<unknown_exception,
no_exception,
rate_limit_exception,
stale_topology_exception,
abort_requested_exception
> reason;
exception_variant()
: reason(no_exception{})
{ }
template<typename Ex>
exception_variant(Ex&& ex)
: reason(std::move(ex))
{ }
std::exception_ptr into_exception_ptr() noexcept;
inline operator bool() const noexcept {
return !std::holds_alternative<no_exception>(reason);
}
};
// Tries to encode the exception into an exception_variant.
// If given exception cannot be encoded into one of the replica exception types,
// returns no_exception.
exception_variant try_encode_replica_exception(std::exception_ptr eptr);
}