76 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			76 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| 
								 | 
							
								// Copyright (c) 2016 Klemens D. Morgenstern
							 | 
						||
| 
								 | 
							
								//
							 | 
						||
| 
								 | 
							
								// 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 BOOST_PROCESS_POSIX_HPP_
							 | 
						||
| 
								 | 
							
								#define BOOST_PROCESS_POSIX_HPP_
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#include <boost/process/detail/posix/fd.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/process/detail/posix/handler.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/process/detail/posix/use_vfork.hpp>
							 | 
						||
| 
								 | 
							
								#include <boost/process/detail/posix/signal.hpp>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/** \file boost/process/posix.hpp
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 *    Header which provides the posix extensions.
							 | 
						||
| 
								 | 
							
								\xmlonly
							 | 
						||
| 
								 | 
							
								<programlisting>
							 | 
						||
| 
								 | 
							
								namespace boost {
							 | 
						||
| 
								 | 
							
								  namespace process {
							 | 
						||
| 
								 | 
							
								    namespace posix {
							 | 
						||
| 
								 | 
							
								      <emphasis>unspecified</emphasis> <globalname alt="boost::process::posix::fd">fd</globalname>;
							 | 
						||
| 
								 | 
							
								      <emphasis>unspecified</emphasis> <globalname alt="boost::process::posix::sig">sig</globalname>;
							 | 
						||
| 
								 | 
							
								      <emphasis>unspecified</emphasis> <globalname alt="boost::process::posix::use_vfork">use_vfork</globalname>;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								</programlisting>
							 | 
						||
| 
								 | 
							
								 *  \endxmlonly
							 | 
						||
| 
								 | 
							
								 *   \warning Only available on posix. See the documentation of [fork](http://pubs.opengroup.org/onlinepubs/009695399/functions/fork.html),
							 | 
						||
| 
								 | 
							
								 *   [execve](http://pubs.opengroup.org/onlinepubs/009695399/functions/execve.html) and
							 | 
						||
| 
								 | 
							
								 *   [vfork](http://pubs.opengroup.org/onlinepubs/009695399/functions/vfork.html).
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								namespace boost { namespace process {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								///Namespace containing the posix exensions.
							 | 
						||
| 
								 | 
							
								namespace posix {
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/** This property lets you modify file-descriptors other than the standard ones (0,1,2).
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * It provides the functions `bind`, which implements [dup2](http://pubs.opengroup.org/onlinepubs/9699919799/functions/dup.html)
							 | 
						||
| 
								 | 
							
								 * and [close](http://pubs.opengroup.org/onlinepubs/9699919799/functions/close.html).
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Close can also be called with a range of file-descriptors to be closed.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								constexpr ::boost::process::detail::posix::fd_ fd;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/** This property lets you modify the handling of `SIGCHLD` for this call. It will be reset afterwards.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								It can be set to default, by the expression `sig.dfl()`, set to ignore with `sig.ign()` or
							 | 
						||
| 
								 | 
							
								assigned a custom handler. A custom handler must have the type `sighandler_t`and can be assigned with the following syntax:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								\code{.cpp}
							 | 
						||
| 
								 | 
							
								sig = handler;
							 | 
						||
| 
								 | 
							
								sig(handler);
							 | 
						||
| 
								 | 
							
								\endcode
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								\warning @ref spawn will automatically use `sig.ign()`, which will override if you pass a custom handler.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								constexpr ::boost::process::detail::posix::sig_       sig;
							 | 
						||
| 
								 | 
							
								/** This property will replace the usage of [fork](http://pubs.opengroup.org/onlinepubs/9699919799/functions/fork.html) by [vfork](http://pubs.opengroup.org/onlinepubs/009695399/functions/vfork.html).
							 | 
						||
| 
								 | 
							
								 \note `vfork` is no longer an official part of the posix standard.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								constexpr ::boost::process::detail::posix::use_vfork_ use_vfork;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								using ::boost::process::detail::posix::sighandler_t;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								}}}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#endif /* BOOST_PROCESS_POSIX_HPP_ */
							 |