⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 completion_condition.hpp

📁 这是国外的resip协议栈
💻 HPP
字号:
//// completion_condition.hpp// ~~~~~~~~~~~~~~~~~~~~~~~~//// Copyright (c) 2003-2007 Christopher M. Kohlhoff (chris at kohlhoff dot com)//// Distributed under the Boost Software License, Version 1.0. (See accompanying// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)//#ifndef ASIO_COMPLETION_CONDITION_HPP#define ASIO_COMPLETION_CONDITION_HPP#if defined(_MSC_VER) && (_MSC_VER >= 1200)# pragma once#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)#include "asio/detail/push_options.hpp"#include "asio/detail/push_options.hpp"#include <cstddef>#include <boost/config.hpp>#include "asio/detail/pop_options.hpp"namespace asio {namespace detail {class transfer_all_t{public:  typedef bool result_type;  template <typename Error>  bool operator()(const Error& err, std::size_t)  {    return !!err;  }};class transfer_at_least_t{public:  typedef bool result_type;  explicit transfer_at_least_t(std::size_t minimum)    : minimum_(minimum)  {  }  template <typename Error>  bool operator()(const Error& err, std::size_t bytes_transferred)  {    return !!err || bytes_transferred >= minimum_;  }private:  std::size_t minimum_;};} // namespace detail/** * @defgroup completion_condition Completion Condition Function Objects * * Function objects used for determining when a read or write operation should * complete. *//*@{*//// Return a completion condition function object that indicates that a read or/// write operation should continue until all of the data has been transferred,/// or until an error occurs./** * This function is used to create an object, of unspecified type, that meets * CompletionCondition requirements. * * @par Example * Reading until a buffer is full: * @code * boost::array<char, 128> buf; * asio::error_code ec; * std::size_t n = asio::read( *     sock, asio::buffer(buf), *     asio::transfer_all(), ec); * if (ec) * { *   // An error occurred. * } * else * { *   // n == 128 * } * @endcode */#if defined(GENERATING_DOCUMENTATION)unspecified transfer_all();#elseinline detail::transfer_all_t transfer_all(){  return detail::transfer_all_t();}#endif/// Return a completion condition function object that indicates that a read or/// write operation should continue until a minimum number of bytes has been/// transferred, or until an error occurs./** * This function is used to create an object, of unspecified type, that meets * CompletionCondition requirements. * * @par Example * Reading until a buffer is full or contains at least 64 bytes: * @code * boost::array<char, 128> buf; * asio::error_code ec; * std::size_t n = asio::read( *     sock, asio::buffer(buf), *     asio::transfer_at_least(64), ec); * if (ec) * { *   // An error occurred. * } * else * { *   // n >= 64 && n <= 128 * } * @endcode */#if defined(GENERATING_DOCUMENTATION)unspecified transfer_at_least(std::size_t minimum);#elseinline detail::transfer_at_least_t transfer_at_least(std::size_t minimum){  return detail::transfer_at_least_t(minimum);}#endif/*@}*/} // namespace asio#include "asio/detail/pop_options.hpp"#endif // ASIO_COMPLETION_CONDITION_HPP

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -