diff options
author | Ondřej Vašík <ovasik@redhat.com> | 2009-09-02 10:34:27 +0100 |
---|---|---|
committer | Pádraig Brady <P@draigBrady.com> | 2009-09-03 10:00:32 +0100 |
commit | 1a94ac4a0524a760c1c3ea7a5ca9032e994785c2 (patch) | |
tree | 5967a5342034bc49f5c9db71272944415e2441ba | |
parent | 1b2d2635eeabce4a2176427dc1de9c1b9b87bc7d (diff) | |
download | coreutils-1a94ac4a0524a760c1c3ea7a5ca9032e994785c2.tar.xz |
cp: don't leak resources for each xattr preservation failure
* src/copy.c (copy_reg): Don't return from the function after an
unsuccessful and required preservation of extended attributes.
This resulted in leaking the copy buffer and file descriptors.
* NEWS (Bug fixes): Mention the fix.
The bug was introduced in coreutils-7.1 via commit 0889381c, 2009-01-23,
"cp/mv: add xattr support".
-rw-r--r-- | NEWS | 3 | ||||
-rw-r--r-- | src/copy.c | 2 |
2 files changed, 4 insertions, 1 deletions
@@ -12,6 +12,9 @@ GNU coreutils NEWS -*- outline -*- cp --reflink --preserve now preserves attributes when cloning a file. [bug introduced in coreutils-7.5] + cp --preserve=xattr no longer leaks resources on each preservation failure. + [bug introduced in coreutils-7.1] + dd now returns non-zero status if it encountered a write error while printing a summary to stderr. [bug introduced in coreutils-6.11] diff --git a/src/copy.c b/src/copy.c index d1e508d7f..e604ec55a 100644 --- a/src/copy.c +++ b/src/copy.c @@ -853,7 +853,7 @@ copy_reg (char const *src_name, char const *dst_name, if (x->preserve_xattr && ! copy_attr_by_fd (src_name, source_desc, dst_name, dest_desc, x) && x->require_preserve_xattr) - return false; + return_val = false; if (x->preserve_mode || x->move_mode) { |