mirror of
https://github.com/bitcoin/bitcoin.git
synced 2026-04-07 22:28:02 +02:00
70f632bda8f Merge bitcoin-core/libmultiprocess#265: ci: set LC_ALL in shell scripts 8e8e564259a Merge bitcoin-core/libmultiprocess#249: fixes for race conditions on disconnects 05d34cc2ec3 ci: set LC_ALL in shell scripts e606fd84a8c Merge bitcoin-core/libmultiprocess#264: ci: reduce nproc multipliers ff0eed1bf18 refactor: Use loop variable in type-context.h ff1d8ba172a refactor: Move type-context.h getParams() call closer to use 1dbc59a4aa3 race fix: m_on_cancel called after request finishes 1643d05ba07 test: m_on_cancel called after request finishes f5509a31fcc race fix: getParams() called after request cancel 4a60c39f24a test: getParams() called after request cancel f11ec29ed20 race fix: worker thread destroyed before it is initialized a1d643348f4 test: worker thread destroyed before it is initialized 336023382c4 ci: reduce nproc multipliers b090beb9651 Merge bitcoin-core/libmultiprocess#256: ci: cache gnu32 nix store be8622816da ci: cache gnu32 nix store 975270b619c Merge bitcoin-core/libmultiprocess#263: ci: bump timeout factor to 40 09f10e5a598 ci: bump timeout factor to 40 db8f76ad290 Merge bitcoin-core/libmultiprocess#253: ci: run some Bitcoin Core CI jobs 55a9b557b19 ci: set Bitcoin Core CI test repetition fb0fc84d556 ci: add TSan job with instrumented libc++ 0f29c38725b ci: add Bitcoin Core IPC tests (ASan + macOS) 3f64320315d Merge bitcoin-core/libmultiprocess#262: ci: enable clang-tidy in macOS job, use nullptr cd9f8bdc9f0 Merge bitcoin-core/libmultiprocess#258: log: add socket connected info message and demote destroy logs to debug b5d6258a42f Merge bitcoin-core/libmultiprocess#255: fix: use unsigned char cast and sizeof in LogEscape escape sequence d94688e2c32 Merge bitcoin-core/libmultiprocess#251: Improved CustomBuildField for std::optional in IPC/libmultiprocess a9499fad755 mp: use nullptr with pthread_threadid_np f499e37850f ci: enable clang-tidy in macOS job 98f1352159d log: add socket connected info message and demote destroy logs to debug 554a481ea73 fix: use unsigned char cast and sizeof in LogEscape escape sequence 1977b9f3f65 Use std::forward in CustomBuildField for std::optional to allow move semantics, resolves FIXME 22bec918c97 Merge bitcoin-core/libmultiprocess#247: type-map: Work around LLVM 22 "out of bounds index" error 8a5e3ae6ed2 Merge bitcoin-core/libmultiprocess#242: proxy-types: add CustomHasField hook to map Cap'n Proto values to null C++ values e8d35246918 Merge bitcoin-core/libmultiprocess#246: doc: Bump version 8 > 9 97d877053b6 proxy-types: add CustomHasField hook for nullable decode paths 8c2f10252c9 refactor: add missing includes to mp/type-data.h b1638aceb40 doc: Bump version 8 > 9 f61af487217 type-map: Work around LLVM 22 "out of bounds index" error git-subtree-dir: src/ipc/libmultiprocess git-subtree-split: 70f632bda8f80449b6240f98da768206a535a04e
68 lines
2.4 KiB
C++
68 lines
2.4 KiB
C++
// Copyright (c) The Bitcoin Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#ifndef MP_PROXY_TYPE_FUNCTION_H
|
|
#define MP_PROXY_TYPE_FUNCTION_H
|
|
|
|
#include <mp/util.h>
|
|
|
|
namespace mp {
|
|
//! Adapter to convert ProxyCallback object call to function object call.
|
|
template <typename Result, typename... Args>
|
|
class ProxyCallbackImpl final : public ProxyCallback<std::function<Result(Args...)>>
|
|
{
|
|
using Fn = std::function<Result(Args...)>;
|
|
Fn m_fn;
|
|
|
|
public:
|
|
ProxyCallbackImpl(Fn fn) : m_fn(std::move(fn)) {}
|
|
Result call(Args&&... args) override { return m_fn(std::forward<Args>(args)...); }
|
|
};
|
|
|
|
template <typename Value, typename FnR, typename... FnParams, typename Output>
|
|
void CustomBuildField(TypeList<std::function<FnR(FnParams...)>>,
|
|
Priority<1>,
|
|
InvokeContext& invoke_context,
|
|
Value&& value,
|
|
Output&& output)
|
|
{
|
|
if (value) {
|
|
using Interface = typename decltype(output.get())::Calls;
|
|
using Callback = ProxyCallbackImpl<FnR, FnParams...>;
|
|
output.set(kj::heap<ProxyServer<Interface>>(
|
|
std::make_shared<Callback>(std::forward<Value>(value)), invoke_context.connection));
|
|
}
|
|
}
|
|
|
|
// ProxyCallFn class is needed because c++11 doesn't support auto lambda parameters.
|
|
// It's equivalent c++14: [invoke_context](auto&& params) {
|
|
// invoke_context->call(std::forward<decltype(params)>(params)...)
|
|
template <typename InvokeContext>
|
|
struct ProxyCallFn
|
|
{
|
|
InvokeContext m_proxy;
|
|
|
|
template <typename... CallParams>
|
|
decltype(auto) operator()(CallParams&&... params) { return this->m_proxy->call(std::forward<CallParams>(params)...); }
|
|
};
|
|
|
|
template <typename FnR, typename... FnParams, typename Input, typename ReadDest>
|
|
decltype(auto) CustomReadField(TypeList<std::function<FnR(FnParams...)>> types,
|
|
Priority<1>,
|
|
InvokeContext& invoke_context,
|
|
Input&& input,
|
|
ReadDest&& read_dest)
|
|
{
|
|
if (CustomHasField(types, invoke_context, input)) {
|
|
using Interface = typename Decay<decltype(input.get())>::Calls;
|
|
auto client = std::make_shared<ProxyClient<Interface>>(
|
|
input.get(), &invoke_context.connection, /* destroy_connection= */ false);
|
|
return read_dest.construct(ProxyCallFn<decltype(client)>{std::move(client)});
|
|
}
|
|
return read_dest.construct();
|
|
};
|
|
} // namespace mp
|
|
|
|
#endif // MP_PROXY_TYPE_FUNCTION_H
|