File: bind_fd.adoc

package info (click to toggle)
boost1.90 1.90.0-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 593,120 kB
  • sloc: cpp: 4,190,908; xml: 196,648; python: 34,618; ansic: 23,145; asm: 5,468; sh: 3,774; makefile: 1,161; perl: 1,020; sql: 728; ruby: 676; yacc: 478; java: 77; lisp: 24; csh: 6
file content (70 lines) | stat: -rw-r--r-- 1,802 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
== `posix/bind_fd.hpp`

`bind_fd` is a utility class to bind a file descriptor to an explicit file descriptor for the child process.

[source,cpp]
----
struct bind_fd
{
  // Inherit file descriptor with the same value.
  /*
  * This will pass descriptor 42 as 42 to the child process:
  * @code
  * process p{"test", {},  posix::bind_fd(42)};
  * @endcode
  */
  bind_fd(int target);

  // Inherit an asio io-object as a given file descriptor to the child process.
  /*
  * This will pass the tcp::socket, as 42 to the child process:
  * @code
  * extern tcp::socket sock;
  * process p{"test", {},  posix::bind_fd(42, sock)};
  * @endcode
  */

  template<typename Stream>
  bind_fd(int target, Stream && str);

  // Inherit a `FILE` as a given file descriptor to the child process.
  /* This will pass the given `FILE*`, as 42 to the child process:

       process p{"test", {},  posix::bind_fd(42, stderr)};

   */
  bind_fd(int target, FILE * f);

  // Inherit a file descriptor with as a different value.
  /* This will pass 24 as 42 to the child process:

       process p{"test", {},  posix::bind_fd(42, 24)};

   */
  bind_fd(int target, int fd):

  // Inherit a null device as a set descriptor.
  /* This will a null device as 42 to the child process:

       process p{"test", {},  posix::bind_fd(42, nullptr)};

   */
  bind_fd(int target, std::nullptr_t);

  // Inherit a newly opened-file as a set descriptor.
  /* This will pass a descriptor to "extra-output.txt" as 42 to the child process:

       process p{"test", {},  posix::bind_fd(42, "extra-output.txt")};

   */
  bind_fd(int target, const filesystem::path & pth, int flags = O_RDWR | O_CREAT);

};
----

Using `bind_fd` can be used to inherit file descriptors explicitly, because no unused one will be.

[source,cpp]
----

----