mirror of
https://github.com/30hours/blah2.git
synced 2024-11-08 12:25:42 +00:00
84 lines
2.2 KiB
C++
84 lines
2.2 KiB
C++
|
//
|
||
|
// connect_pipe.hpp
|
||
|
// ~~~~~~~~~~~~~~~~
|
||
|
//
|
||
|
// Copyright (c) 2003-2022 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_CONNECT_PIPE_HPP
|
||
|
#define ASIO_CONNECT_PIPE_HPP
|
||
|
|
||
|
#if defined(_MSC_VER) && (_MSC_VER >= 1200)
|
||
|
# pragma once
|
||
|
#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
|
||
|
|
||
|
#include "asio/detail/config.hpp"
|
||
|
|
||
|
#if defined(ASIO_HAS_PIPE) \
|
||
|
|| defined(GENERATING_DOCUMENTATION)
|
||
|
|
||
|
#include "asio/basic_readable_pipe.hpp"
|
||
|
#include "asio/basic_writable_pipe.hpp"
|
||
|
#include "asio/error.hpp"
|
||
|
|
||
|
#include "asio/detail/push_options.hpp"
|
||
|
|
||
|
namespace asio {
|
||
|
namespace detail {
|
||
|
|
||
|
#if defined(ASIO_HAS_IOCP)
|
||
|
typedef HANDLE native_pipe_handle;
|
||
|
#else // defined(ASIO_HAS_IOCP)
|
||
|
typedef int native_pipe_handle;
|
||
|
#endif // defined(ASIO_HAS_IOCP)
|
||
|
|
||
|
ASIO_DECL void create_pipe(native_pipe_handle p[2],
|
||
|
asio::error_code& ec);
|
||
|
|
||
|
ASIO_DECL void close_pipe(native_pipe_handle p);
|
||
|
|
||
|
} // namespace detail
|
||
|
|
||
|
/// Connect two pipe ends using an anonymous pipe.
|
||
|
/**
|
||
|
* @param read_end The read end of the pipe.
|
||
|
*
|
||
|
* @param write_end The write end of the pipe.
|
||
|
*
|
||
|
* @throws asio::system_error Thrown on failure.
|
||
|
*/
|
||
|
template <typename Executor1, typename Executor2>
|
||
|
void connect_pipe(basic_readable_pipe<Executor1>& read_end,
|
||
|
basic_writable_pipe<Executor2>& write_end);
|
||
|
|
||
|
/// Connect two pipe ends using an anonymous pipe.
|
||
|
/**
|
||
|
* @param read_end The read end of the pipe.
|
||
|
*
|
||
|
* @param write_end The write end of the pipe.
|
||
|
*
|
||
|
* @throws asio::system_error Thrown on failure.
|
||
|
*
|
||
|
* @param ec Set to indicate what error occurred, if any.
|
||
|
*/
|
||
|
template <typename Executor1, typename Executor2>
|
||
|
ASIO_SYNC_OP_VOID connect_pipe(basic_readable_pipe<Executor1>& read_end,
|
||
|
basic_writable_pipe<Executor2>& write_end, asio::error_code& ec);
|
||
|
|
||
|
} // namespace asio
|
||
|
|
||
|
#include "asio/detail/pop_options.hpp"
|
||
|
|
||
|
#include "asio/impl/connect_pipe.hpp"
|
||
|
#if defined(ASIO_HEADER_ONLY)
|
||
|
# include "asio/impl/connect_pipe.ipp"
|
||
|
#endif // defined(ASIO_HEADER_ONLY)
|
||
|
|
||
|
#endif // defined(ASIO_HAS_PIPE)
|
||
|
// || defined(GENERATING_DOCUMENTATION)
|
||
|
|
||
|
#endif // ASIO_CONNECT_PIPE_HPP
|