mirror of
https://github.com/codership/wsrep-lib.git
synced 2025-04-19 21:02:17 +03:00
Added a wsrep::thread_service interface to allow application to inject instrumented thread, mutex and condition variable implementation for provider. The interface is defined in include/wsrep/thread_service.hpp. Sample implementation is provided in dbsim/db_threads.[h|c]pp. This patch will also clean up some remaining dependencies to wsrep-API compilation units so that the dependency to wsrep-API is header only. This will extending the provider support to later wsrep-API versions.
50 lines
1.8 KiB
C++
50 lines
1.8 KiB
C++
/*
|
|
* Copyright (C) 2018 Codership Oy <info@codership.com>
|
|
*
|
|
* This file is part of wsrep-lib.
|
|
*
|
|
* Wsrep-lib is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Wsrep-lib 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 wsrep-lib. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
|
|
/** @file compiler.hpp
|
|
*
|
|
* Compiler specific macro definitions.
|
|
*
|
|
* WSREP_NOEXCEPT - Specifies that the method/function does not throw. If
|
|
* and exception is thrown inside, std::terminate is called
|
|
* without propagating the exception.
|
|
* Set to "noexcept" if the compiler supports it, otherwise
|
|
* left empty.
|
|
* WSREP_NORETURN - Indicates that the method/function does not return.
|
|
* Set to attribute "[[noreturn]]" if the compiler supports,
|
|
* it, otherwise "__attribute__((noreturn))".
|
|
* WSREP_OVERRIDE - Set to "override" if the compiler supports it, otherwise
|
|
* left empty.
|
|
* WSREP_UNUSED - Can be used to mark variables which may be present in
|
|
* debug builds but not in release builds.
|
|
*/
|
|
|
|
|
|
#if __cplusplus >= 201103L
|
|
#define WSREP_NOEXCEPT noexcept
|
|
#define WSREP_NORETURN [[noreturn]]
|
|
#define WSREP_OVERRIDE override
|
|
#else
|
|
#define WSREP_NOEXCEPT
|
|
#define WSREP_NORETURN __attribute__((noreturn))
|
|
#define WSREP_OVERRIDE
|
|
#endif // __cplusplus >= 201103L
|
|
#define WSREP_UNUSED __attribute__((unused))
|