summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.bin/mkfifo/mkfifo.120
-rw-r--r--usr.bin/mkfifo/mkfifo.c46
2 files changed, 54 insertions, 12 deletions
diff --git a/usr.bin/mkfifo/mkfifo.1 b/usr.bin/mkfifo/mkfifo.1
index 63a1352deb9..10f72708b4f 100644
--- a/usr.bin/mkfifo/mkfifo.1
+++ b/usr.bin/mkfifo/mkfifo.1
@@ -1,4 +1,4 @@
-.\" $OpenBSD: mkfifo.1,v 1.2 1996/06/26 05:37:11 deraadt Exp $
+.\" $OpenBSD: mkfifo.1,v 1.3 1996/08/28 07:31:49 etheisen Exp $
.\" $NetBSD: mkfifo.1,v 1.4 1994/12/23 07:16:54 jtc Exp $
.\"
.\" Copyright (c) 1990, 1993
@@ -42,14 +42,15 @@
.Os BSD 4.4
.Sh NAME
.Nm mkfifo
-.Nd make fifos
+.Nd make fifos or sockets
.Sh SYNOPSIS
.Nm mkfifo
.Op Fl m Ar mode
-.Ar fifo_name ...
+.Op Fl s
+.Ar filename ...
.Sh DESCRIPTION
.Nm Mkfifo
-creates the fifos requested, in the order specified,
+creates the fifos or AF_UNIX sockets requested, in the order specified,
using mode
.Li \&0666
modified by the current
@@ -68,6 +69,9 @@ and
.Dq -
operators are interpreted relative to an assumed initial mode of
.Dq a=rw
+.It Fl s
+Create AF_UNIX socket names in the file system.
+This is a non-standard extension.
.El
.Pp
.Nm Mkfifo
@@ -79,9 +83,13 @@ exits 0 if successful, and >0 if an error occurred.
.Xr mkdir 1 ,
.Xr mknod 1 ,
.Xr rm 1 ,
-.Xr mkfifo 2
+.Xr mkfifo 2 ,
+.Xr socket 2 ,
+.Xr bind 2
.Sh STANDARDS
-The
+With the exception of the
+.Fl s
+flag, the
.Nm mkfifo
utility is expected to be
.St -p1003.2-92
diff --git a/usr.bin/mkfifo/mkfifo.c b/usr.bin/mkfifo/mkfifo.c
index 38517d752b0..58736052c46 100644
--- a/usr.bin/mkfifo/mkfifo.c
+++ b/usr.bin/mkfifo/mkfifo.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mkfifo.c,v 1.2 1996/06/26 05:37:11 deraadt Exp $ */
+/* $OpenBSD: mkfifo.c,v 1.3 1996/08/28 07:31:51 etheisen Exp $ */
/* $NetBSD: mkfifo.c,v 1.7 1994/12/23 07:16:56 jtc Exp $ */
/*
@@ -44,7 +44,7 @@ static char copyright[] =
#if 0
static char sccsid[] = "@(#)mkfifo.c 8.2 (Berkeley) 1/5/94";
#endif
-static char rcsid[] = "$OpenBSD: mkfifo.c,v 1.2 1996/06/26 05:37:11 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: mkfifo.c,v 1.3 1996/08/28 07:31:51 etheisen Exp $";
#endif /* not lint */
#include <stdio.h>
@@ -53,12 +53,16 @@ static char rcsid[] = "$OpenBSD: mkfifo.c,v 1.2 1996/06/26 05:37:11 deraadt Exp
#include <locale.h>
#include <errno.h>
#include <sys/types.h>
+#include <sys/socket.h>
+#include <sys/un.h>
#include <sys/stat.h>
#include <unistd.h>
#include <err.h>
static void usage();
+int mksocket;
+
int
main(argc, argv)
int argc;
@@ -67,6 +71,8 @@ main(argc, argv)
int ch, exitval;
void * set;
mode_t mode;
+ int sock;
+ struct sockaddr_un name;
setlocale (LC_ALL, "");
@@ -75,7 +81,7 @@ main(argc, argv)
modified by the file creation mask */
mode = 0666 & ~umask(0);
- while ((ch = getopt(argc, argv, "m:")) != -1)
+ while ((ch = getopt(argc, argv, "m:s")) != -1)
switch(ch) {
case 'm':
if (!(set = setmode(optarg))) {
@@ -87,6 +93,9 @@ main(argc, argv)
a=rw. */
mode = getmode (set, 0666);
break;
+ case 's':
+ mksocket = 1;
+ break;
case '?':
default:
usage();
@@ -96,18 +105,43 @@ main(argc, argv)
if (argv[0] == NULL)
usage();
- for (exitval = 0; *argv; ++argv) {
- if (mkfifo(*argv, mode) < 0) {
+ if (mksocket) {
+ for (exitval = 0; *argv; ++argv) {
+ if ((sock = socket(AF_UNIX, SOCK_DGRAM, 0)) < 0)
+ goto error;
+
+ name.sun_family = AF_UNIX;
+ strncpy(name.sun_path, *argv, sizeof(name.sun_path)-1);
+ name.sun_path[sizeof(name.sun_path) - 1];
+ if (bind(sock, (struct sockaddr *)&name,
+ SUN_LEN(&name)) < 0)
+ goto error;
+
+ if (chmod(*argv, mode) < 0) {
+ unlink(*argv);
+ goto error;
+ }
+
+ continue;
+error:
warn("%s", *argv);
exitval = 1;
}
}
+ else {
+ for (exitval = 0; *argv; ++argv) {
+ if (mkfifo(*argv, mode) < 0) {
+ warn("%s", *argv);
+ exitval = 1;
+ }
+ }
+ }
exit(exitval);
}
void
usage()
{
- (void)fprintf(stderr, "usage: mkfifo [-m mode] fifoname ...\n");
+ (void)fprintf(stderr, "usage: mkfifo [-m mode] [-s] filename ...\n");
exit(1);
}