git: a9c0baa1d063 - stable/13 - fork.2: Add a simple use pattern

Konstantin Belousov kib at FreeBSD.org
Thu Aug 12 12:39:24 UTC 2021


The branch stable/13 has been updated by kib:

URL: https://cgit.FreeBSD.org/src/commit/?id=a9c0baa1d063b219e9ff71076bfb05231e58acf4

commit a9c0baa1d063b219e9ff71076bfb05231e58acf4
Author:     Mateusz Piotrowski <0mp at FreeBSD.org>
AuthorDate: 2021-04-17 21:10:48 +0000
Commit:     Konstantin Belousov <kib at FreeBSD.org>
CommitDate: 2021-08-12 12:37:54 +0000

    fork.2: Add a simple use pattern
    
    (cherry picked from commit c4207d867c201a726aa3157e09262f72166c89c4)
---
 lib/libc/sys/fork.2 | 38 +++++++++++++++++++++++++++++++++++++-
 1 file changed, 37 insertions(+), 1 deletion(-)

diff --git a/lib/libc/sys/fork.2 b/lib/libc/sys/fork.2
index 3e55530827c5..d43ade6a483e 100644
--- a/lib/libc/sys/fork.2
+++ b/lib/libc/sys/fork.2
@@ -28,7 +28,7 @@
 .\"	@(#)fork.2	8.1 (Berkeley) 6/4/93
 .\" $FreeBSD$
 .\"
-.Dd December 1, 2017
+.Dd April 17, 2021
 .Dt FORK 2
 .Os
 .Sh NAME
@@ -99,6 +99,42 @@ to the parent process, no child process is created, and the global
 variable
 .Va errno
 is set to indicate the error.
+.Sh EXAMPLES
+The following example shows a common pattern of how
+.Fn fork
+is used in practice.
+.Bd -literal -offset indent
+#include <err.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+
+int
+main(void)
+{
+	pid_t pid;
+
+	switch (pid = fork()) {
+	case -1:
+		err(1, "Failed to fork");
+	case 0:
+		printf("Hello from child process!\en");
+		exit(0);
+	default:
+		break;
+	}
+
+	printf("Hello from parent process (child's PID: %d)!\en", pid);
+
+	return (0);
+}
+.Ed
+.Pp
+The output of such a program is along the lines of:
+.Bd -literal -offset indent
+Hello from parent (child's PID: 27804)!
+Hello from child process!
+.Ed
 .Sh ERRORS
 The
 .Fn fork


More information about the dev-commits-src-branches mailing list