summaryrefslogtreecommitdiffstats
path: root/contrib/cpio/src/copypass.c
diff options
context:
space:
mode:
authortjr <tjr@FreeBSD.org>2005-10-01 05:36:39 +0000
committertjr <tjr@FreeBSD.org>2005-10-01 05:36:39 +0000
commit058cbad8094e4a18727e0f0366e1f5b2cbc25468 (patch)
treeec559e2bc8ca33412fa4fcc075aacb838ed2d707 /contrib/cpio/src/copypass.c
parentd2ed906427de5fad605fdfb6abee1ab90f082333 (diff)
downloadFreeBSD-src-058cbad8094e4a18727e0f0366e1f5b2cbc25468.zip
FreeBSD-src-058cbad8094e4a18727e0f0366e1f5b2cbc25468.tar.gz
Merge from old copyin.c rev 1.5, copypass.c rev 1.2: Create fifos using
mkfifo() instead of attempting to create them using mknod().
Diffstat (limited to 'contrib/cpio/src/copypass.c')
-rw-r--r--contrib/cpio/src/copypass.c20
1 files changed, 16 insertions, 4 deletions
diff --git a/contrib/cpio/src/copypass.c b/contrib/cpio/src/copypass.c
index db6f327..0827f9c 100644
--- a/contrib/cpio/src/copypass.c
+++ b/contrib/cpio/src/copypass.c
@@ -1,3 +1,5 @@
+/* $FreeBSD$ */
+
/* copypass.c - cpio copy pass sub-function.
Copyright (C) 1990, 1991, 1992, 2001, 2003, 2004 Free Software Foundation, Inc.
@@ -311,13 +313,23 @@ process_copy_pass ()
if (link_res < 0)
{
- res = mknod (output_name.ds_string, in_file_stat.st_mode,
- in_file_stat.st_rdev);
+#ifdef S_ISFIFO
+ if (S_ISFIFO (in_file_stat.st_mode))
+ res = mkfifo (output_name.ds_string, in_file_stat.st_mode);
+ else
+#endif
+ res = mknod (output_name.ds_string, in_file_stat.st_mode,
+ in_file_stat.st_rdev);
if (res < 0 && create_dir_flag)
{
create_all_directories (output_name.ds_string);
- res = mknod (output_name.ds_string, in_file_stat.st_mode,
- in_file_stat.st_rdev);
+#ifdef S_ISFIFO
+ if (S_ISFIFO (in_file_stat.st_mode))
+ res = mkfifo (output_name.ds_string, in_file_stat.st_mode);
+ else
+#endif
+ res = mknod (output_name.ds_string, in_file_stat.st_mode,
+ in_file_stat.st_rdev);
}
if (res < 0)
{
OpenPOWER on IntegriCloud