Accepting request 35734 from home:mseben:branches:Archiving
Copy from home:mseben:branches:Archiving/cpio via accept of submit request 35734 revision 8. Request was accepted with message: OBS-URL: https://build.opensuse.org/request/show/35734 OBS-URL: https://build.opensuse.org/package/show/Archiving/cpio?expand=0&rev=19
This commit is contained in:
parent
b384fd5839
commit
abb8c85948
@ -1,139 +0,0 @@
|
|||||||
--- src/copypass.c
|
|
||||||
+++ src/copypass.c
|
|
||||||
@@ -239,15 +239,23 @@ process_copy_pass ()
|
|
||||||
cdf_flag = 1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
- res = mkdir (output_name.ds_string, in_file_stat.st_mode);
|
|
||||||
+ res = mkdir (output_name.ds_string, in_file_stat.st_mode & ~077);
|
|
||||||
|
|
||||||
}
|
|
||||||
else
|
|
||||||
- res = 0;
|
|
||||||
+ {
|
|
||||||
+ if (!no_chown_flag && (out_file_stat.st_mode & 077) != 0
|
|
||||||
+ && chmod (output_name.ds_string, out_file_stat.st_mode & 07700) < 0)
|
|
||||||
+ {
|
|
||||||
+ error (0, errno, "%s: chmod", output_name.ds_string);
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
+ res = 0;
|
|
||||||
+ }
|
|
||||||
if (res < 0 && create_dir_flag)
|
|
||||||
{
|
|
||||||
create_all_directories (output_name.ds_string);
|
|
||||||
- res = mkdir (output_name.ds_string, in_file_stat.st_mode);
|
|
||||||
+ res = mkdir (output_name.ds_string, in_file_stat.st_mode & ~077);
|
|
||||||
}
|
|
||||||
if (res < 0)
|
|
||||||
{
|
|
||||||
@@ -290,12 +298,12 @@ process_copy_pass ()
|
|
||||||
|
|
||||||
if (link_res < 0)
|
|
||||||
{
|
|
||||||
- res = mknod (output_name.ds_string, in_file_stat.st_mode,
|
|
||||||
+ res = mknod (output_name.ds_string, in_file_stat.st_mode & ~077,
|
|
||||||
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,
|
|
||||||
+ res = mknod (output_name.ds_string, in_file_stat.st_mode & ~077,
|
|
||||||
in_file_stat.st_rdev);
|
|
||||||
}
|
|
||||||
if (res < 0)
|
|
||||||
--- src/copyin.c
|
|
||||||
+++ src/copyin.c
|
|
||||||
@@ -186,11 +186,12 @@ list_file(struct cpio_file_stat* file_hd
|
|
||||||
|
|
||||||
static int
|
|
||||||
try_existing_file (struct cpio_file_stat* file_hdr, int in_file_des,
|
|
||||||
- int *existing_dir)
|
|
||||||
+ int *existing_dir, mode_t *existing_mode)
|
|
||||||
{
|
|
||||||
struct stat file_stat;
|
|
||||||
|
|
||||||
*existing_dir = false;
|
|
||||||
+ *existing_mode = 0;
|
|
||||||
if (lstat (file_hdr->c_name, &file_stat) == 0)
|
|
||||||
{
|
|
||||||
if (S_ISDIR (file_stat.st_mode)
|
|
||||||
@@ -200,6 +201,7 @@ try_existing_file (struct cpio_file_stat
|
|
||||||
we are trying to create, don't complain about
|
|
||||||
it. */
|
|
||||||
*existing_dir = true;
|
|
||||||
+ *existing_mode = file_stat.st_mode;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
else if (!unconditional_flag
|
|
||||||
@@ -567,7 +569,7 @@ copyin_regular_file (struct cpio_file_st
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
-copyin_directory (struct cpio_file_stat *file_hdr, int existing_dir)
|
|
||||||
+copyin_directory (struct cpio_file_stat *file_hdr, int existing_dir, mode_t existing_mode)
|
|
||||||
{
|
|
||||||
int res; /* Result of various function calls. */
|
|
||||||
#ifdef HPUX_CDF
|
|
||||||
@@ -610,14 +612,22 @@ copyin_directory (struct cpio_file_stat
|
|
||||||
cdf_flag = 1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
- res = mkdir (file_hdr->c_name, file_hdr->c_mode);
|
|
||||||
+ res = mkdir (file_hdr->c_name, file_hdr->c_mode & ~077);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
- res = 0;
|
|
||||||
+ {
|
|
||||||
+ if (!no_chown_flag && (existing_mode & 077) != 0
|
|
||||||
+ && chmod (file_hdr->c_name, existing_mode & 07700) < 0)
|
|
||||||
+ {
|
|
||||||
+ error (0, errno, "%s: chmod", file_hdr->c_name);
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+ res = 0;
|
|
||||||
+ }
|
|
||||||
if (res < 0 && create_dir_flag)
|
|
||||||
{
|
|
||||||
create_all_directories (file_hdr->c_name);
|
|
||||||
- res = mkdir (file_hdr->c_name, file_hdr->c_mode);
|
|
||||||
+ res = mkdir (file_hdr->c_name, file_hdr->c_mode & ~077);
|
|
||||||
}
|
|
||||||
if (res < 0)
|
|
||||||
{
|
|
||||||
@@ -692,12 +702,12 @@ copyin_device (struct cpio_file_stat* fi
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
- res = mknod (file_hdr->c_name, file_hdr->c_mode,
|
|
||||||
+ res = mknod (file_hdr->c_name, file_hdr->c_mode & ~077,
|
|
||||||
makedev (file_hdr->c_rdev_maj, file_hdr->c_rdev_min));
|
|
||||||
if (res < 0 && create_dir_flag)
|
|
||||||
{
|
|
||||||
create_all_directories (file_hdr->c_name);
|
|
||||||
- res = mknod (file_hdr->c_name, file_hdr->c_mode,
|
|
||||||
+ res = mknod (file_hdr->c_name, file_hdr->c_mode & ~077,
|
|
||||||
makedev (file_hdr->c_rdev_maj, file_hdr->c_rdev_min));
|
|
||||||
}
|
|
||||||
if (res < 0)
|
|
||||||
@@ -772,9 +782,10 @@ static void
|
|
||||||
copyin_file (struct cpio_file_stat* file_hdr, int in_file_des)
|
|
||||||
{
|
|
||||||
int existing_dir=0;
|
|
||||||
+ mode_t existing_mode;
|
|
||||||
|
|
||||||
if (!to_stdout_option
|
|
||||||
- && try_existing_file (file_hdr, in_file_des, &existing_dir) < 0)
|
|
||||||
+ && try_existing_file (file_hdr, in_file_des, &existing_dir, &existing_mode) < 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
/* Do the real copy or link. */
|
|
||||||
@@ -785,7 +796,7 @@ copyin_file (struct cpio_file_stat* file
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CP_IFDIR:
|
|
||||||
- copyin_directory (file_hdr, existing_dir);
|
|
||||||
+ copyin_directory(file_hdr, existing_dir, existing_mode);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CP_IFCHR:
|
|
@ -1,52 +0,0 @@
|
|||||||
From 9bc39283e4cc6ab9e5913ccbf766998eab4ff093 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Sergey Poznyakoff <gray@gnu.org.ua>
|
|
||||||
Date: Mon, 01 Mar 2010 08:49:03 +0000
|
|
||||||
Subject: Bugfixes in rtapelib
|
|
||||||
|
|
||||||
* lib/rmt.h (rmtcreat): Use fcntl O_ macros insead of
|
|
||||||
their hardcoded values.
|
|
||||||
* lib/rtapelib.c (rmt_read__,rmt_ioctl__): Prevent
|
|
||||||
potential overflow.
|
|
||||||
---
|
|
||||||
diff --git a/lib/rmt.h b/lib/rmt.h
|
|
||||||
index 50f037c..2ce9dc5 100644
|
|
||||||
--- a/lib/rmt.h
|
|
||||||
+++ b/lib/rmt.h
|
|
||||||
@@ -61,7 +61,7 @@ extern bool force_local_option;
|
|
||||||
|
|
||||||
#define rmtcreat(dev_name, mode, command) \
|
|
||||||
(_remdev (dev_name) \
|
|
||||||
- ? rmt_open__ (dev_name, 1 | O_CREAT, __REM_BIAS, command) \
|
|
||||||
+ ? rmt_open__ (dev_name, O_CREAT | O_WRONLY, __REM_BIAS, command) \
|
|
||||||
: creat (dev_name, mode))
|
|
||||||
|
|
||||||
#define rmtlstat(dev_name, muffer) \
|
|
||||||
diff --git a/lib/rtapelib.c b/lib/rtapelib.c
|
|
||||||
index 02ad1e7..cb645db 100644
|
|
||||||
--- a/lib/rtapelib.c
|
|
||||||
+++ b/lib/rtapelib.c
|
|
||||||
@@ -573,7 +573,8 @@ rmt_read__ (int handle, char *buffer, size_t length)
|
|
||||||
|
|
||||||
sprintf (command_buffer, "R%lu\n", (unsigned long) length);
|
|
||||||
if (do_command (handle, command_buffer) == -1
|
|
||||||
- || (status = get_status (handle)) == SAFE_READ_ERROR)
|
|
||||||
+ || (status = get_status (handle)) == SAFE_READ_ERROR
|
|
||||||
+ || status > length)
|
|
||||||
return SAFE_READ_ERROR;
|
|
||||||
|
|
||||||
for (counter = 0; counter < status; counter += rlen, buffer += rlen)
|
|
||||||
@@ -709,6 +710,12 @@ rmt_ioctl__ (int handle, int operation, char *argument)
|
|
||||||
|| (status = get_status (handle), status == -1))
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
+ if (status > sizeof (struct mtop))
|
|
||||||
+ {
|
|
||||||
+ errno = EOVERFLOW;
|
|
||||||
+ return -1;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
for (; status > 0; status -= counter, argument += counter)
|
|
||||||
{
|
|
||||||
counter = safe_read (READ_SIDE (handle), argument, status);
|
|
||||||
--
|
|
||||||
cgit v0.8.2.1
|
|
@ -1,8 +0,0 @@
|
|||||||
--- lib/Makefile.am.orig 2009-07-09 09:41:26.000000000 +0200
|
|
||||||
+++ lib/Makefile.am 2009-07-09 09:41:17.000000000 +0200
|
|
||||||
@@ -37,4 +37,5 @@
|
|
||||||
sysdep.c\
|
|
||||||
system.h\
|
|
||||||
error.c\
|
|
||||||
+ ../src/fatal.c \
|
|
||||||
names.c
|
|
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:def23150e4e081599ecb013736f4403617fefbb6f6e6806dc6a98129913d79d5
|
|
||||||
size 951395
|
|
3
cpio-2.11.tar.bz2
Normal file
3
cpio-2.11.tar.bz2
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:bb820bfd96e74fc6ce43104f06fe733178517e7f5d1cdee553773e8eff7d5bbd
|
||||||
|
size 1018483
|
@ -2,10 +2,12 @@ Index: src/copyin.c
|
|||||||
===================================================================
|
===================================================================
|
||||||
--- src/copyin.c.orig
|
--- src/copyin.c.orig
|
||||||
+++ src/copyin.c
|
+++ src/copyin.c
|
||||||
@@ -1565,6 +1565,19 @@ process_copy_in ()
|
@@ -1484,7 +1484,20 @@ process_copy_in ()
|
||||||
if (dot_flag)
|
|
||||||
fputc ('\n', stderr);
|
fputc ('\n', stderr);
|
||||||
|
|
||||||
|
apply_delayed_set_stat ();
|
||||||
|
-
|
||||||
|
+
|
||||||
+ if (tty_in)
|
+ if (tty_in)
|
||||||
+ {
|
+ {
|
||||||
+ fclose(tty_in);
|
+ fclose(tty_in);
|
@ -1,12 +1,17 @@
|
|||||||
--- src/mt.c
|
Index: src/mt.c
|
||||||
|
===================================================================
|
||||||
|
--- src/mt.c.orig
|
||||||
+++ src/mt.c
|
+++ src/mt.c
|
||||||
@@ -664,11 +664,20 @@
|
@@ -413,11 +413,18 @@ parse_opt (int key, char *arg, struct ar
|
||||||
{
|
{
|
||||||
tapedev = getenv ("TAPE");
|
tapedev = getenv ("TAPE");
|
||||||
if (tapedev == NULL)
|
if (tapedev == NULL)
|
||||||
-#ifdef DEFTAPE /* From sys/mtio.h. */
|
-#ifdef DEFTAPE /* From sys/mtio.h. */
|
||||||
- tapedev = DEFTAPE;
|
- tapedev = DEFTAPE;
|
||||||
-#else
|
-#else
|
||||||
|
- error (MT_EXIT_INVOP, 0, _("no tape device specified"));
|
||||||
|
-#endif
|
||||||
|
+
|
||||||
+/* Suse doesn't have /dev/tape as link to /dev/nst0 any more.
|
+/* Suse doesn't have /dev/tape as link to /dev/nst0 any more.
|
||||||
+Instead it uses udev and creates different names in /dev/tape/by-id/ directory.
|
+Instead it uses udev and creates different names in /dev/tape/by-id/ directory.
|
||||||
+If it is SCSI tape storage then it creates /dev/tape/by-id/scsi--nst
|
+If it is SCSI tape storage then it creates /dev/tape/by-id/scsi--nst
|
||||||
@ -18,10 +23,6 @@
|
|||||||
+/* #ifdef DEFTAPE * From sys/mtio.h. * */
|
+/* #ifdef DEFTAPE * From sys/mtio.h. * */
|
||||||
+# define DEFSUSETAPE "/dev/nst0"
|
+# define DEFSUSETAPE "/dev/nst0"
|
||||||
+ tapedev = DEFSUSETAPE;
|
+ tapedev = DEFSUSETAPE;
|
||||||
+/* #else
|
|
||||||
error (1, 0, _("no tape device specified"));
|
|
||||||
-#endif
|
|
||||||
+#endif */
|
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
#ifdef MTDENS
|
|
@ -1,163 +1,13 @@
|
|||||||
--- cpio-2.9/src/copyin.c
|
Redhat-bugzilla: 430835
|
||||||
+++ cpio-2.9/src/copyin.c
|
|
||||||
@@ -186,12 +186,11 @@
|
|
||||||
|
|
||||||
static int
|
|
||||||
try_existing_file (struct cpio_file_stat* file_hdr, int in_file_des,
|
|
||||||
- int *existing_dir, mode_t *existing_mode)
|
|
||||||
+ int *existing_dir)
|
|
||||||
{
|
|
||||||
struct stat file_stat;
|
|
||||||
|
|
||||||
*existing_dir = false;
|
* revert make_path code to previous state, which worked better
|
||||||
- *existing_mode = 0;
|
* this can be dropped when permission issues are solved in upstream
|
||||||
if (lstat (file_hdr->c_name, &file_stat) == 0)
|
|
||||||
{
|
|
||||||
if (S_ISDIR (file_stat.st_mode)
|
|
||||||
@@ -201,7 +200,6 @@
|
|
||||||
we are trying to create, don't complain about
|
|
||||||
it. */
|
|
||||||
*existing_dir = true;
|
|
||||||
- *existing_mode = file_stat.st_mode;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
else if (!unconditional_flag
|
|
||||||
@@ -569,7 +567,7 @@
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
-copyin_directory (struct cpio_file_stat *file_hdr, int existing_dir, mode_t existing_mode)
|
|
||||||
+copyin_directory (struct cpio_file_stat *file_hdr, int existing_dir)
|
|
||||||
{
|
|
||||||
int res; /* Result of various function calls. */
|
|
||||||
#ifdef HPUX_CDF
|
|
||||||
@@ -612,22 +610,14 @@
|
|
||||||
cdf_flag = 1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
- res = mkdir (file_hdr->c_name, file_hdr->c_mode & ~077);
|
|
||||||
+ res = mkdir (file_hdr->c_name, file_hdr->c_mode);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
- {
|
|
||||||
- if (!no_chown_flag && (existing_mode & 077) != 0
|
|
||||||
- && chmod (file_hdr->c_name, existing_mode & 07700) < 0)
|
|
||||||
- {
|
|
||||||
- error (0, errno, "%s: chmod", file_hdr->c_name);
|
|
||||||
- return;
|
|
||||||
- }
|
|
||||||
- res = 0;
|
|
||||||
- }
|
|
||||||
+ res = 0;
|
|
||||||
if (res < 0 && create_dir_flag)
|
|
||||||
{
|
|
||||||
create_all_directories (file_hdr->c_name);
|
|
||||||
- res = mkdir (file_hdr->c_name, file_hdr->c_mode & ~077);
|
|
||||||
+ res = mkdir (file_hdr->c_name, file_hdr->c_mode);
|
|
||||||
}
|
|
||||||
if (res < 0)
|
|
||||||
{
|
|
||||||
@@ -702,12 +692,12 @@
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
- res = mknod (file_hdr->c_name, file_hdr->c_mode & ~077,
|
|
||||||
+ res = mknod (file_hdr->c_name, file_hdr->c_mode,
|
|
||||||
makedev (file_hdr->c_rdev_maj, file_hdr->c_rdev_min));
|
|
||||||
if (res < 0 && create_dir_flag)
|
|
||||||
{
|
|
||||||
create_all_directories (file_hdr->c_name);
|
|
||||||
- res = mknod (file_hdr->c_name, file_hdr->c_mode & ~077,
|
|
||||||
+ res = mknod (file_hdr->c_name, file_hdr->c_mode,
|
|
||||||
makedev (file_hdr->c_rdev_maj, file_hdr->c_rdev_min));
|
|
||||||
}
|
|
||||||
if (res < 0)
|
|
||||||
@@ -782,10 +772,9 @@
|
|
||||||
copyin_file (struct cpio_file_stat* file_hdr, int in_file_des)
|
|
||||||
{
|
|
||||||
int existing_dir=0;
|
|
||||||
- mode_t existing_mode;
|
|
||||||
|
|
||||||
if (!to_stdout_option
|
diff -up cpio-2.9/src/extern.h.dir_perm cpio-2.9/src/extern.h
|
||||||
- && try_existing_file (file_hdr, in_file_des, &existing_dir, &existing_mode) < 0)
|
--- cpio-2.9/src/extern.h.dir_perm 2007-06-28 14:59:38.000000000 +0200
|
||||||
+ && try_existing_file (file_hdr, in_file_des, &existing_dir) < 0)
|
+++ cpio-2.9/src/extern.h 2008-03-03 11:57:43.000000000 +0100
|
||||||
return;
|
@@ -140,8 +140,8 @@ void process_args (int argc, char *argv[
|
||||||
|
|
||||||
/* Do the real copy or link. */
|
|
||||||
@@ -796,7 +785,7 @@
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CP_IFDIR:
|
|
||||||
- copyin_directory(file_hdr, existing_dir, existing_mode);
|
|
||||||
+ copyin_directory (file_hdr, existing_dir);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CP_IFCHR:
|
|
||||||
@@ -1576,8 +1565,6 @@
|
|
||||||
if (dot_flag)
|
|
||||||
fputc ('\n', stderr);
|
|
||||||
|
|
||||||
- apply_delayed_set_stat ();
|
|
||||||
-
|
|
||||||
if (append_flag)
|
|
||||||
return;
|
|
||||||
|
|
||||||
--- cpio-2.9/src/copypass.c
|
|
||||||
+++ cpio-2.9/src/copypass.c
|
|
||||||
@@ -239,23 +239,15 @@
|
|
||||||
cdf_flag = 1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
- res = mkdir (output_name.ds_string, in_file_stat.st_mode & ~077);
|
|
||||||
+ res = mkdir (output_name.ds_string, in_file_stat.st_mode);
|
|
||||||
|
|
||||||
}
|
|
||||||
else
|
|
||||||
- {
|
|
||||||
- if (!no_chown_flag && (out_file_stat.st_mode & 077) != 0
|
|
||||||
- && chmod (output_name.ds_string, out_file_stat.st_mode & 07700) < 0)
|
|
||||||
- {
|
|
||||||
- error (0, errno, "%s: chmod", output_name.ds_string);
|
|
||||||
- continue;
|
|
||||||
- }
|
|
||||||
- res = 0;
|
|
||||||
- }
|
|
||||||
+ res = 0;
|
|
||||||
if (res < 0 && create_dir_flag)
|
|
||||||
{
|
|
||||||
create_all_directories (output_name.ds_string);
|
|
||||||
- res = mkdir (output_name.ds_string, in_file_stat.st_mode & ~077);
|
|
||||||
+ res = mkdir (output_name.ds_string, in_file_stat.st_mode);
|
|
||||||
}
|
|
||||||
if (res < 0)
|
|
||||||
{
|
|
||||||
@@ -298,12 +290,12 @@
|
|
||||||
|
|
||||||
if (link_res < 0)
|
|
||||||
{
|
|
||||||
- res = mknod (output_name.ds_string, in_file_stat.st_mode & ~077,
|
|
||||||
+ 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 & ~077,
|
|
||||||
+ res = mknod (output_name.ds_string, in_file_stat.st_mode,
|
|
||||||
in_file_stat.st_rdev);
|
|
||||||
}
|
|
||||||
if (res < 0)
|
|
||||||
@@ -373,8 +365,6 @@
|
|
||||||
if (dot_flag)
|
|
||||||
fputc ('\n', stderr);
|
|
||||||
|
|
||||||
- apply_delayed_set_stat ();
|
|
||||||
-
|
|
||||||
if (!quiet_flag)
|
|
||||||
{
|
|
||||||
size_t blocks = (output_bytes + io_block_size - 1) / io_block_size;
|
|
||||||
--- cpio-2.9/src/extern.h
|
|
||||||
+++ cpio-2.9/src/extern.h
|
|
||||||
@@ -140,8 +140,8 @@
|
|
||||||
void initialize_buffers (void);
|
void initialize_buffers (void);
|
||||||
|
|
||||||
/* makepath.c */
|
/* makepath.c */
|
||||||
@ -168,9 +18,36 @@
|
|||||||
|
|
||||||
/* tar.c */
|
/* tar.c */
|
||||||
void write_out_tar_header (struct cpio_file_stat *file_hdr, int out_des);
|
void write_out_tar_header (struct cpio_file_stat *file_hdr, int out_des);
|
||||||
--- cpio-2.9/src/makepath.c
|
diff -up cpio-2.9/src/util.c.dir_perm cpio-2.9/src/util.c
|
||||||
+++ cpio-2.9/src/makepath.c
|
--- cpio-2.9/src/util.c.dir_perm 2007-06-28 15:04:51.000000000 +0200
|
||||||
@@ -36,8 +36,10 @@
|
+++ cpio-2.9/src/util.c 2008-03-03 11:45:00.000000000 +0100
|
||||||
|
@@ -618,14 +618,7 @@ create_all_directories (char *name)
|
||||||
|
error (2, 0, _("virtual memory exhausted"));
|
||||||
|
|
||||||
|
if (dir[0] != '.' || dir[1] != '\0')
|
||||||
|
- {
|
||||||
|
- const char *fmt;
|
||||||
|
- if (warn_option & CPIO_WARN_INTERDIR)
|
||||||
|
- fmt = _("Creating intermediate directory `%s'");
|
||||||
|
- else
|
||||||
|
- fmt = NULL;
|
||||||
|
- make_path (dir, -1, -1, fmt);
|
||||||
|
- }
|
||||||
|
+ make_path (dir, mode, 0700, -1, -1, (char *) NULL);
|
||||||
|
|
||||||
|
free (dir);
|
||||||
|
}
|
||||||
|
diff -up cpio-2.9/src/makepath.c.dir_perm cpio-2.9/src/makepath.c
|
||||||
|
--- cpio-2.9/src/makepath.c.dir_perm 2007-06-28 15:09:47.000000000 +0200
|
||||||
|
+++ cpio-2.9/src/makepath.c 2008-03-03 11:45:00.000000000 +0100
|
||||||
|
@@ -29,15 +29,14 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
-#include "cpiohdr.h"
|
||||||
|
-#include "dstring.h"
|
||||||
|
-#include "extern.h"
|
||||||
|
|
||||||
/* Ensure that the directory ARGPATH exists.
|
/* Ensure that the directory ARGPATH exists.
|
||||||
Remove any trailing slashes from ARGPATH before calling this function.
|
Remove any trailing slashes from ARGPATH before calling this function.
|
||||||
|
|
||||||
@ -240,7 +117,7 @@
|
|||||||
while (*slash == '/')
|
while (*slash == '/')
|
||||||
slash++;
|
slash++;
|
||||||
while ((slash = strchr (slash, '/')))
|
while ((slash = strchr (slash, '/')))
|
||||||
@@ -91,9 +112,10 @@
|
@@ -91,9 +112,10 @@ make_path (char *argpath,
|
||||||
*(slash -1) = '\0';
|
*(slash -1) = '\0';
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -252,7 +129,7 @@
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -101,18 +123,24 @@
|
@@ -101,18 +123,24 @@ make_path (char *argpath,
|
||||||
if (verbose_fmt_string != NULL)
|
if (verbose_fmt_string != NULL)
|
||||||
error (0, 0, verbose_fmt_string, dirpath);
|
error (0, 0, verbose_fmt_string, dirpath);
|
||||||
|
|
||||||
@ -287,7 +164,7 @@
|
|||||||
#ifdef HPUX_CDF
|
#ifdef HPUX_CDF
|
||||||
if (iscdf)
|
if (iscdf)
|
||||||
{
|
{
|
||||||
@@ -129,6 +157,7 @@
|
@@ -129,6 +157,7 @@ make_path (char *argpath,
|
||||||
else if (!S_ISDIR (stats.st_mode))
|
else if (!S_ISDIR (stats.st_mode))
|
||||||
{
|
{
|
||||||
error (0, 0, _("`%s' exists but is not a directory"), dirpath);
|
error (0, 0, _("`%s' exists but is not a directory"), dirpath);
|
||||||
@ -295,7 +172,7 @@
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -143,7 +172,7 @@
|
@@ -143,7 +172,7 @@ make_path (char *argpath,
|
||||||
/* We're done making leading directories.
|
/* We're done making leading directories.
|
||||||
Make the final component of the path. */
|
Make the final component of the path. */
|
||||||
|
|
||||||
@ -304,7 +181,7 @@
|
|||||||
{
|
{
|
||||||
/* In some cases, if the final component in dirpath was `.' then we
|
/* In some cases, if the final component in dirpath was `.' then we
|
||||||
just got an EEXIST error from that last mkdir(). If that's
|
just got an EEXIST error from that last mkdir(). If that's
|
||||||
@@ -153,24 +182,51 @@
|
@@ -153,24 +182,51 @@ make_path (char *argpath,
|
||||||
(!S_ISDIR (stats.st_mode) ) )
|
(!S_ISDIR (stats.st_mode) ) )
|
||||||
{
|
{
|
||||||
error (0, errno, _("cannot make directory `%s'"), dirpath);
|
error (0, errno, _("cannot make directory `%s'"), dirpath);
|
||||||
@ -368,7 +245,7 @@
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -179,10 +235,33 @@
|
@@ -179,10 +235,33 @@ make_path (char *argpath,
|
||||||
if (!S_ISDIR (stats.st_mode))
|
if (!S_ISDIR (stats.st_mode))
|
||||||
{
|
{
|
||||||
error (0, 0, _("`%s' exists but is not a directory"), dirpath);
|
error (0, 0, _("`%s' exists but is not a directory"), dirpath);
|
||||||
@ -402,21 +279,3 @@
|
|||||||
+ umask (oldmask);
|
+ umask (oldmask);
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
--- cpio-2.9/src/util.c
|
|
||||||
+++ cpio-2.9/src/util.c
|
|
||||||
@@ -618,14 +618,7 @@
|
|
||||||
error (2, 0, _("virtual memory exhausted"));
|
|
||||||
|
|
||||||
if (dir[0] != '.' || dir[1] != '\0')
|
|
||||||
- {
|
|
||||||
- const char *fmt;
|
|
||||||
- if (warn_option & CPIO_WARN_INTERDIR)
|
|
||||||
- fmt = _("Creating intermediate directory `%s'");
|
|
||||||
- else
|
|
||||||
- fmt = NULL;
|
|
||||||
- make_path (dir, -1, -1, fmt);
|
|
||||||
- }
|
|
||||||
+ make_path (dir, mode, 0700, -1, -1, (char *) NULL);
|
|
||||||
|
|
||||||
free (dir);
|
|
||||||
}
|
|
@ -103,7 +103,7 @@ Index: src/Makefile.am
|
|||||||
===================================================================
|
===================================================================
|
||||||
--- src/Makefile.am.orig
|
--- src/Makefile.am.orig
|
||||||
+++ src/Makefile.am
|
+++ src/Makefile.am
|
||||||
@@ -18,7 +18,7 @@
|
@@ -19,7 +19,7 @@
|
||||||
|
|
||||||
INCLUDES=-I. -I.. -I$(top_srcdir)/gnu -I$(top_builddir)/gnu -I$(top_srcdir)/lib -I$(top_builddir)/lib
|
INCLUDES=-I. -I.. -I$(top_srcdir)/gnu -I$(top_builddir)/gnu -I$(top_srcdir)/lib -I$(top_builddir)/lib
|
||||||
|
|
||||||
@ -116,16 +116,16 @@ Index: src/copyin.c
|
|||||||
===================================================================
|
===================================================================
|
||||||
--- src/copyin.c.orig
|
--- src/copyin.c.orig
|
||||||
+++ src/copyin.c
|
+++ src/copyin.c
|
||||||
@@ -771,7 +771,7 @@ copyin_link(struct cpio_file_stat *file_
|
@@ -689,7 +689,7 @@ copyin_link(struct cpio_file_stat *file_
|
||||||
static void
|
static void
|
||||||
copyin_file (struct cpio_file_stat* file_hdr, int in_file_des)
|
copyin_file (struct cpio_file_stat *file_hdr, int in_file_des)
|
||||||
{
|
{
|
||||||
- int existing_dir;
|
- int existing_dir;
|
||||||
+ int existing_dir=0;
|
+ int existing_dir=0;
|
||||||
|
|
||||||
if (!to_stdout_option
|
if (!to_stdout_option
|
||||||
&& try_existing_file (file_hdr, in_file_des, &existing_dir) < 0)
|
&& try_existing_file (file_hdr, in_file_des, &existing_dir) < 0)
|
||||||
@@ -1360,6 +1360,7 @@ process_copy_in ()
|
@@ -1278,6 +1278,7 @@ process_copy_in ()
|
||||||
int in_file_des; /* Input file descriptor. */
|
int in_file_des; /* Input file descriptor. */
|
||||||
char skip_file; /* Flag for use with patterns. */
|
char skip_file; /* Flag for use with patterns. */
|
||||||
int i; /* Loop index variable. */
|
int i; /* Loop index variable. */
|
||||||
@ -133,7 +133,7 @@ Index: src/copyin.c
|
|||||||
|
|
||||||
newdir_umask = umask (0); /* Reset umask to preserve modes of
|
newdir_umask = umask (0); /* Reset umask to preserve modes of
|
||||||
created files */
|
created files */
|
||||||
@@ -1468,8 +1469,10 @@ process_copy_in ()
|
@@ -1386,8 +1387,10 @@ process_copy_in ()
|
||||||
for (i = 0; i < num_patterns
|
for (i = 0; i < num_patterns
|
||||||
&& skip_file == copy_matching_files; i++)
|
&& skip_file == copy_matching_files; i++)
|
||||||
{
|
{
|
||||||
@ -149,7 +149,7 @@ Index: src/mt.c
|
|||||||
===================================================================
|
===================================================================
|
||||||
--- src/mt.c.orig
|
--- src/mt.c.orig
|
||||||
+++ src/mt.c
|
+++ src/mt.c
|
||||||
@@ -17,6 +17,10 @@
|
@@ -18,6 +18,10 @@
|
||||||
02110-1301 USA
|
02110-1301 USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -160,7 +160,7 @@ Index: src/mt.c
|
|||||||
|
|
||||||
/* If -f is not given, the environment variable TAPE is used;
|
/* If -f is not given, the environment variable TAPE is used;
|
||||||
if that is not set, a default device defined in sys/mtio.h is used.
|
if that is not set, a default device defined in sys/mtio.h is used.
|
||||||
@@ -51,9 +55,51 @@
|
@@ -52,9 +56,51 @@
|
||||||
retension Rewind the tape, then wind it to the end of the reel,
|
retension Rewind the tape, then wind it to the end of the reel,
|
||||||
then rewind it again.
|
then rewind it again.
|
||||||
erase Erase the tape.
|
erase Erase the tape.
|
||||||
@ -212,9 +212,9 @@ Index: src/mt.c
|
|||||||
#include <system.h>
|
#include <system.h>
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@@ -105,6 +151,85 @@ int atoi ();
|
@@ -90,6 +136,110 @@
|
||||||
void exit ();
|
#define MT_EXIT_INVOP 1
|
||||||
#endif
|
#define MT_EXIT_FAILURE 2
|
||||||
|
|
||||||
+#if defined(linux) || defined(__linux)
|
+#if defined(linux) || defined(__linux)
|
||||||
+#define MTDATCOMP 1000 /* Random unused number. */
|
+#define MTDATCOMP 1000 /* Random unused number. */
|
||||||
@ -294,11 +294,36 @@ Index: src/mt.c
|
|||||||
+ {-1, NULL}};
|
+ {-1, NULL}};
|
||||||
+#endif
|
+#endif
|
||||||
+
|
+
|
||||||
|
+char *cbnames[] =
|
||||||
|
+{
|
||||||
|
+#ifdef MT_ST_BOOLEANS
|
||||||
|
+ "stoptions",
|
||||||
|
+#endif
|
||||||
|
+#ifdef MT_ST_WRITE_THRESHOLD
|
||||||
|
+ "stwrthreshold",
|
||||||
|
+#endif
|
||||||
|
+ NULL
|
||||||
|
+};
|
||||||
+
|
+
|
||||||
char *opnames[] =
|
+int count_bits[] =
|
||||||
|
+{
|
||||||
|
+#ifdef MT_ST_BOOLEANS
|
||||||
|
+ MT_ST_BOOLEANS,
|
||||||
|
+#endif
|
||||||
|
+#ifdef MT_ST_WRITE_THRESHOLD
|
||||||
|
+ MT_ST_WRITE_THRESHOLD,
|
||||||
|
+#endif
|
||||||
|
+ 0
|
||||||
|
+};
|
||||||
|
+
|
||||||
|
+#ifdef MT_TAPE_INFO
|
||||||
|
+ struct mt_tape_info tapes[] = MT_TAPE_INFO;
|
||||||
|
+#endif
|
||||||
|
+
|
||||||
|
char const * const opnames[] =
|
||||||
{
|
{
|
||||||
"eof", "weof", "fsf", "bsf", "fsr", "bsr",
|
"eof",
|
||||||
@@ -114,6 +239,8 @@ char *opnames[] =
|
@@ -108,6 +258,8 @@ char const * const opnames[] =
|
||||||
#endif
|
#endif
|
||||||
#ifdef MTEOM
|
#ifdef MTEOM
|
||||||
"eom",
|
"eom",
|
||||||
@ -307,7 +332,7 @@ Index: src/mt.c
|
|||||||
#endif
|
#endif
|
||||||
#ifdef MTRETEN
|
#ifdef MTRETEN
|
||||||
"retension",
|
"retension",
|
||||||
@@ -128,6 +255,39 @@ char *opnames[] =
|
@@ -122,6 +274,39 @@ char const * const opnames[] =
|
||||||
#ifdef MTSEEK
|
#ifdef MTSEEK
|
||||||
"seek",
|
"seek",
|
||||||
#endif
|
#endif
|
||||||
@ -347,7 +372,7 @@ Index: src/mt.c
|
|||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -141,6 +301,8 @@ short operations[] =
|
@@ -144,6 +329,8 @@ short operations[] =
|
||||||
#endif
|
#endif
|
||||||
#ifdef MTEOM
|
#ifdef MTEOM
|
||||||
MTEOM,
|
MTEOM,
|
||||||
@ -356,7 +381,7 @@ Index: src/mt.c
|
|||||||
#endif
|
#endif
|
||||||
#ifdef MTRETEN
|
#ifdef MTRETEN
|
||||||
MTRETEN,
|
MTRETEN,
|
||||||
@@ -155,9 +317,69 @@ short operations[] =
|
@@ -158,6 +345,39 @@ short operations[] =
|
||||||
#ifdef MTSEEK
|
#ifdef MTSEEK
|
||||||
MTSEEK,
|
MTSEEK,
|
||||||
#endif
|
#endif
|
||||||
@ -393,51 +418,22 @@ Index: src/mt.c
|
|||||||
+#ifdef MTDENS
|
+#ifdef MTDENS
|
||||||
+ MTDENS,
|
+ MTDENS,
|
||||||
+#endif
|
+#endif
|
||||||
0
|
|
||||||
};
|
};
|
||||||
|
|
||||||
+char *cbnames[] =
|
ARGMATCH_VERIFY (opnames, operations);
|
||||||
+{
|
@@ -286,10 +506,23 @@ void
|
||||||
+#ifdef MT_ST_BOOLEANS
|
|
||||||
+ "stoptions",
|
|
||||||
+#endif
|
|
||||||
+#ifdef MT_ST_WRITE_THRESHOLD
|
|
||||||
+ "stwrthreshold",
|
|
||||||
+#endif
|
|
||||||
+ NULL
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
+int count_bits[] =
|
|
||||||
+{
|
|
||||||
+#ifdef MT_ST_BOOLEANS
|
|
||||||
+ MT_ST_BOOLEANS,
|
|
||||||
+#endif
|
|
||||||
+#ifdef MT_ST_WRITE_THRESHOLD
|
|
||||||
+ MT_ST_WRITE_THRESHOLD,
|
|
||||||
+#endif
|
|
||||||
+ 0
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
+#ifdef MT_TAPE_INFO
|
|
||||||
+ struct mt_tape_info tapes[] = MT_TAPE_INFO;
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
+
|
|
||||||
struct option longopts[] =
|
|
||||||
{
|
|
||||||
{"file", 1, NULL, 'f'},
|
|
||||||
@@ -200,10 +422,22 @@ void
|
|
||||||
print_status (char *dev, int desc)
|
print_status (char *dev, int desc)
|
||||||
{
|
{
|
||||||
struct mtget status;
|
struct mtget status;
|
||||||
+#ifdef MT_TAPE_INFO
|
-
|
||||||
|
+ #ifdef MT_TAPE_INFO
|
||||||
+ struct mt_tape_info *mt;
|
+ struct mt_tape_info *mt;
|
||||||
+#endif
|
+ #endif
|
||||||
|
+
|
||||||
if (rmtioctl (desc, MTIOCGET, (char*)&status) == -1)
|
if (rmtioctl (desc, MTIOCGET, (char*)&status) == -1)
|
||||||
error (2, errno, _("%s: rmtioctl failed"), dev);
|
error (MT_EXIT_FAILURE, errno, _("%s: rmtioctl failed"), dev);
|
||||||
|
|
||||||
+#ifdef MT_TAPE_INFO
|
+ #ifdef MT_TAPE_INFO
|
||||||
+ for (mt = tapes; mt->t_type; mt++)
|
+ for (mt = tapes; mt->t_type; mt++)
|
||||||
+ if (mt->t_type == status.mt_type) break;
|
+ if (mt->t_type == status.mt_type) break;
|
||||||
+ if (mt->t_type != 0)
|
+ if (mt->t_type != 0)
|
||||||
@ -445,11 +441,12 @@ Index: src/mt.c
|
|||||||
+ printf ("drive type = %s\n", mt->t_name);
|
+ printf ("drive type = %s\n", mt->t_name);
|
||||||
+ }
|
+ }
|
||||||
+ else
|
+ else
|
||||||
+#endif
|
+ #endif
|
||||||
|
+
|
||||||
printf ("drive type = %d\n", (int) status.mt_type);
|
printf ("drive type = %d\n", (int) status.mt_type);
|
||||||
#if defined(hpux) || defined(__hpux)
|
#if defined(hpux) || defined(__hpux)
|
||||||
printf ("drive status (high) = %d\n", (int) status.mt_dsreg1);
|
printf ("drive status (high) = %d\n", (int) status.mt_dsreg1);
|
||||||
@@ -217,7 +451,177 @@ print_status (char *dev, int desc)
|
@@ -303,7 +536,177 @@ print_status (char *dev, int desc)
|
||||||
printf ("file number = %d\n", (int) status.mt_fileno);
|
printf ("file number = %d\n", (int) status.mt_fileno);
|
||||||
printf ("block number = %d\n", (int) status.mt_blkno);
|
printf ("block number = %d\n", (int) status.mt_blkno);
|
||||||
#endif
|
#endif
|
||||||
@ -606,7 +603,7 @@ Index: src/mt.c
|
|||||||
+ printf("Compression off.\n");
|
+ printf("Compression off.\n");
|
||||||
+
|
+
|
||||||
+ return 1;
|
+ return 1;
|
||||||
}
|
+}
|
||||||
+#endif
|
+#endif
|
||||||
+
|
+
|
||||||
+#ifdef MTTELL
|
+#ifdef MTTELL
|
||||||
@ -621,24 +618,24 @@ Index: src/mt.c
|
|||||||
+ error (2, errno, "%s", dev);
|
+ error (2, errno, "%s", dev);
|
||||||
+ printf("At block %ld.\n", position.mt_blkno);
|
+ printf("At block %ld.\n", position.mt_blkno);
|
||||||
+
|
+
|
||||||
+}
|
}
|
||||||
+#endif
|
+#endif
|
||||||
+
|
+
|
||||||
|
|
||||||
void
|
void
|
||||||
usage (FILE *fp,int status)
|
fatal_exit ()
|
||||||
@@ -276,7 +680,7 @@ main (int argc, char **argv)
|
@@ -314,7 +717,7 @@ fatal_exit ()
|
||||||
if (optind == argc)
|
int
|
||||||
usage (stderr, 1);
|
main (int argc, char **argv)
|
||||||
|
|
||||||
- i = argmatch (argv[optind], opnames);
|
|
||||||
+ i = argmatch (argv[optind], opnames,NULL,0);
|
|
||||||
if (i < 0)
|
|
||||||
{
|
{
|
||||||
argmatch_invalid ("tape operation", argv[optind], i);
|
- int tapedesc;
|
||||||
@@ -308,10 +712,29 @@ main (int argc, char **argv)
|
+ int tapedesc,i;
|
||||||
#endif
|
|
||||||
}
|
setlocale (LC_ALL, "");
|
||||||
|
bindtextdomain (PACKAGE, LOCALEDIR);
|
||||||
|
@@ -327,13 +730,32 @@ main (int argc, char **argv)
|
||||||
|
if (argp_parse (&argp, argc, argv, ARGP_IN_ORDER, NULL, NULL))
|
||||||
|
exit (MT_EXIT_INVOP);
|
||||||
|
|
||||||
+#ifdef MTDENS
|
+#ifdef MTDENS
|
||||||
+ if (operation == MTDENS)
|
+ if (operation == MTDENS)
|
||||||
@ -650,24 +647,28 @@ Index: src/mt.c
|
|||||||
+ }
|
+ }
|
||||||
+#endif
|
+#endif
|
||||||
+
|
+
|
||||||
if ( (operation == MTWEOF)
|
switch (operation)
|
||||||
|
{
|
||||||
|
case MTWEOF:
|
||||||
#ifdef MTERASE
|
#ifdef MTERASE
|
||||||
|| (operation == MTERASE)
|
case MTERASE:
|
||||||
#endif
|
#endif
|
||||||
|
- tapedesc = rmtopen (tapedev, O_WRONLY, 0, rsh_command_option);
|
||||||
+#ifdef MTWSM
|
+#ifdef MTWSM
|
||||||
+ || (operation == MTWSM)
|
+ case MTWSM:
|
||||||
+#endif
|
+#endif
|
||||||
+#ifdef MTSETDRVBUFFER
|
+#ifdef MTSETDRVBUFFER
|
||||||
+ || (operation == MTSETDRVBUFFER)
|
+ case MTSETDRVBUFFER:
|
||||||
+#endif
|
+#endif
|
||||||
+#ifdef MTDATCOMP
|
+#ifdef MTDATCOMP
|
||||||
+ || (operation == MTDATCOMP)
|
+ case MTDATCOMP:
|
||||||
+#endif
|
+#endif
|
||||||
)
|
+ tapedesc = rmtopen (tapedev, O_WRONLY, 0, rsh_command_option);
|
||||||
tapedesc = rmtopen (tapedev, O_WRONLY, 0, rsh_command_option);
|
break;
|
||||||
else
|
|
||||||
@@ -320,6 +743,17 @@ main (int argc, char **argv)
|
default:
|
||||||
error (1, errno, _("%s: rmtopen failed"), tapedev);
|
@@ -344,6 +766,17 @@ main (int argc, char **argv)
|
||||||
|
error (MT_EXIT_INVOP, errno, _("%s: rmtopen failed"), tapedev);
|
||||||
check_type (tapedev, tapedesc);
|
check_type (tapedev, tapedesc);
|
||||||
|
|
||||||
+#ifdef MTDATCOMP
|
+#ifdef MTDATCOMP
|
||||||
@ -684,11 +685,11 @@ Index: src/mt.c
|
|||||||
if (operation == MTASF)
|
if (operation == MTASF)
|
||||||
{
|
{
|
||||||
perform_operation (tapedev, tapedesc, MTREW, 1);
|
perform_operation (tapedev, tapedesc, MTREW, 1);
|
||||||
@@ -328,6 +762,7 @@ main (int argc, char **argv)
|
@@ -352,6 +785,7 @@ main (int argc, char **argv)
|
||||||
perform_operation (tapedev, tapedesc, operation, count);
|
perform_operation (tapedev, tapedesc, operation, count);
|
||||||
if (operation == MTNOP)
|
if (operation == MTNOP)
|
||||||
print_status (tapedev, tapedesc);
|
print_status (tapedev, tapedesc);
|
||||||
+ }
|
+ }
|
||||||
|
|
||||||
if (rmtclose (tapedesc) == -1)
|
if (rmtclose (tapedesc) == -1)
|
||||||
error (2, errno, _("%s: rmtclose failed"), tapedev);
|
error (MT_EXIT_FAILURE, errno, _("%s: rmtclose failed"), tapedev);
|
@ -1,20 +1,26 @@
|
|||||||
--- src/mt.c
|
Index: src/mt.c
|
||||||
|
===================================================================
|
||||||
|
--- src/mt.c.orig
|
||||||
+++ src/mt.c
|
+++ src/mt.c
|
||||||
@@ -694,9 +694,9 @@
|
@@ -723,11 +723,11 @@ main (int argc, char **argv)
|
||||||
|| (operation == MTDATCOMP)
|
#ifdef MTDATCOMP
|
||||||
|
case MTDATCOMP:
|
||||||
#endif
|
#endif
|
||||||
)
|
|
||||||
- tapedesc = rmtopen (tapedev, O_WRONLY, 0, rsh_command_option);
|
- tapedesc = rmtopen (tapedev, O_WRONLY, 0, rsh_command_option);
|
||||||
+ tapedesc = rmtopen (tapedev, O_WRONLY | O_NONBLOCK, 0, rsh_command_option);
|
+ tapedesc = rmtopen (tapedev, O_WRONLY | O_NONBLOCK, 0, rsh_command_option);
|
||||||
else
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
- tapedesc = rmtopen (tapedev, O_RDONLY, 0, rsh_command_option);
|
- tapedesc = rmtopen (tapedev, O_RDONLY, 0, rsh_command_option);
|
||||||
+ tapedesc = rmtopen (tapedev, O_RDONLY | O_NONBLOCK, 0, rsh_command_option);
|
+ tapedesc = rmtopen (tapedev, O_RDONLY | O_NONBLOCK, 0, rsh_command_option);
|
||||||
|
}
|
||||||
|
|
||||||
if (tapedesc == -1)
|
if (tapedesc == -1)
|
||||||
error (1, errno, _("%s: rmtopen failed"), tapedev);
|
Index: src/util.c
|
||||||
check_type (tapedev, tapedesc);
|
===================================================================
|
||||||
--- src/util.c
|
--- src/util.c.orig
|
||||||
+++ src/util.c
|
+++ src/util.c
|
||||||
@@ -753,14 +753,14 @@
|
@@ -767,14 +767,14 @@ open_archive (char *file)
|
||||||
copy_in = process_copy_in;
|
copy_in = process_copy_in;
|
||||||
|
|
||||||
if (copy_function == copy_in)
|
if (copy_function == copy_in)
|
15
cpio.changes
15
cpio.changes
@ -1,3 +1,18 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Fri Mar 12 16:34:39 UTC 2010 - mseben@novell.com
|
||||||
|
|
||||||
|
- updated to 2.11
|
||||||
|
* Fix mt build.
|
||||||
|
* In copy-in mode, if directory attributes do not permit writing to it,
|
||||||
|
setting them is delayed until the end of run. This allows to
|
||||||
|
correctly extract files in such directories.
|
||||||
|
* In copy-in mode, permissions of a directory are restored if it
|
||||||
|
appears in the file list after files in it (e.g. in listings
|
||||||
|
produced by find . -depth). This fixes debian bug #458079.
|
||||||
|
* Fix possible memory overflow in the rmt client code (CVE-2010-0624).
|
||||||
|
- deprecated heap_overflow_in_rtapelib.patch,chmodRaceC.patch and
|
||||||
|
include_fatal_c.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Wed Mar 3 09:29:23 UTC 2010 - mseben@novell.com
|
Wed Mar 3 09:29:23 UTC 2010 - mseben@novell.com
|
||||||
|
|
||||||
|
30
cpio.spec
30
cpio.spec
@ -23,29 +23,24 @@ Url: http://www.gnu.org/software/cpio/cpio.html
|
|||||||
License: GPLv3
|
License: GPLv3
|
||||||
Group: Productivity/Archiving/Compression
|
Group: Productivity/Archiving/Compression
|
||||||
AutoReqProv: on
|
AutoReqProv: on
|
||||||
Version: 2.10
|
Version: 2.11
|
||||||
Release: 6
|
Release: 6
|
||||||
Summary: A Backup and Archiving Utility
|
Summary: A Backup and Archiving Utility
|
||||||
Source: %{name}-%{version}.tar.bz2
|
Source: %{name}-%{version}.tar.bz2
|
||||||
Patch2: %{name}-%{version}-use_new_ascii_format.patch
|
Patch2: %{name}-use_new_ascii_format.patch
|
||||||
Patch3: %{name}-%{version}-mt.patch
|
#oouch what a ...?! pieces of code grabed from mt_st package to add missing functionality (e.g. density info)
|
||||||
Patch4: %{name}-%{version}-use_sbin_rmt.patch
|
Patch3: %{name}-mt.patch
|
||||||
Patch5: %{name}-%{version}-open_nonblock.patch
|
Patch4: %{name}-use_sbin_rmt.patch
|
||||||
Patch7: %{name}-%{version}-chmodRaceC.patch
|
Patch5: %{name}-open_nonblock.patch
|
||||||
#patch dir_perm reverts some things which were added by patch #7 chmodRaceC
|
#patch dir_perm reverts some things which were added by patch #7 chmodRaceC
|
||||||
Patch14: %{name}-%{version}-dir_perm.patch
|
Patch14: %{name}-dir_perm.patch
|
||||||
Patch15: %{name}-%{version}-eof_tape_handling.patch
|
Patch15: %{name}-eof_tape_handling.patch
|
||||||
# make posibble to have device nodes with major number > 127
|
# make posibble to have device nodes with major number > 127
|
||||||
# Red Hat Bugzilla #450109
|
# Red Hat Bugzilla #450109
|
||||||
Patch17: %{name}-%{version}-dev_number.patch
|
Patch17: %{name}-dev_number.patch
|
||||||
Patch18: %{name}-%{version}-default_tape_dev.patch
|
Patch18: %{name}-default_tape_dev.patch
|
||||||
#PATCH-FIX-UPSTREAM include_fatal_c.patch fix undefined ref in mt build
|
|
||||||
Patch19: %{name}-%{version}-include_fatal_c.patch
|
|
||||||
#PATCH-FIX-UPSTREAM cpio-2.10-close_files_after_copy.patch
|
#PATCH-FIX-UPSTREAM cpio-2.10-close_files_after_copy.patch
|
||||||
Patch20: %{name}-%{version}-close_files_after_copy.patch
|
Patch20: %{name}-close_files_after_copy.patch
|
||||||
#fix possible heap overflow in rtapelib.c bnc#579475
|
|
||||||
Patch21: %{name}-%{version}-heap_overflow_in_rtapelib.patch
|
|
||||||
PreReq: %install_info_prereq
|
|
||||||
PreReq: %install_info_prereq
|
PreReq: %install_info_prereq
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
Requires: %{name}-lang = %{version}
|
Requires: %{name}-lang = %{version}
|
||||||
@ -76,14 +71,11 @@ Authors:
|
|||||||
%patch3
|
%patch3
|
||||||
%patch4
|
%patch4
|
||||||
%patch5
|
%patch5
|
||||||
%patch7
|
|
||||||
%patch14 -p1
|
%patch14 -p1
|
||||||
%patch15
|
%patch15
|
||||||
%patch17
|
%patch17
|
||||||
%patch18
|
%patch18
|
||||||
%patch19
|
|
||||||
%patch20
|
%patch20
|
||||||
%patch21 -p1
|
|
||||||
#chmod 755 .
|
#chmod 755 .
|
||||||
#chmod u+w *
|
#chmod u+w *
|
||||||
#chmod a+r *
|
#chmod a+r *
|
||||||
|
Loading…
Reference in New Issue
Block a user