// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- // vim: ts=8 sw=2 smarttab /* * Ceph - scalable distributed file system * * Copyright (C) 2020 Red Hat * Author: Adam C. Emerson * * This is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software * Foundation. See file COPYING. * */ #include #include #include #include namespace ceph::async { template auto bind_ea(const Executor& executor, const Allocator& allocator, Completion&& completion) { return bind_allocator(allocator, boost::asio::bind_executor( executor, std::forward(completion))); } // Bind `Completion` to the executor and allocator of `Proto` template auto bind_like(const Proto& proto, Completion&& completion) { return bind_ea(boost::asio::get_associated_executor(proto), boost::asio::get_associated_allocator(proto), std::forward(completion)); } }