/* * Copyright 2015-present ScyllaDB */ /* SPDX-License-Identifier: AGPL-3.0-or-later */ #include #include #include #include #include #include #include #include #include "exceptions.hh" #include bool check_exception(system_error_lambda_t f) { auto e = std::current_exception(); if (!e) { return false; } try { std::rethrow_exception(e); } catch (std::system_error &e) { return f(e); } catch (...) { return false; } return false; } bool is_system_error_errno(int err_no) { return check_exception([err_no] (const std::system_error &e) { auto code = e.code(); return code.value() == err_no && code.category() == std::system_category(); }); } bool should_stop_on_system_error(const std::system_error& e) { if (e.code().category() == std::system_category()) { // Whitelist of errors that don't require us to stop the server: switch (e.code().value()) { case EEXIST: case ENOENT: return false; default: break; } } return true; } bool is_timeout_exception(std::exception_ptr e) { try { std::rethrow_exception(e); } catch (seastar::rpc::timeout_error& unused) { return true; } catch (seastar::semaphore_timed_out& unused) { return true; } catch (seastar::timed_out_error& unused) { return true; } catch (const std::nested_exception& e) { return is_timeout_exception(e.nested_ptr()); } catch (...) { } return false; }