GNU bug report logs -
#30919
[grep: input file './x’ is also the output] too late!.. have a null file.
Previous Next
Reported by: openforum <at> davidpbrown.co.uk
Date: Fri, 23 Mar 2018 19:37:01 UTC
Severity: normal
Tags: notabug
Done: Eric Blake <eblake <at> redhat.com>
Bug is archived. No further changes may be made.
To add a comment to this bug, you must first unarchive it, by sending
a message to control AT debbugs.gnu.org, with unarchive 30919 in the body.
You can then email your comments to 30919 AT debbugs.gnu.org in the normal way.
Toggle the display of automated, internal messages from the tracker.
Report forwarded
to
bug-grep <at> gnu.org
:
bug#30919
; Package
grep
.
(Fri, 23 Mar 2018 19:37:02 GMT)
Full text and
rfc822 format available.
Acknowledgement sent
to
openforum <at> davidpbrown.co.uk
:
New bug report received and forwarded. Copy sent to
bug-grep <at> gnu.org
.
(Fri, 23 Mar 2018 19:37:02 GMT)
Full text and
rfc822 format available.
Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):
Hi,
Surprised that the error is noted but only after the file gets clobbered.
Example:
=====================
echo "blah" > ./x
grep -v 'foo' ./x > ./x
# grep: input file './x’ is also the output
# results with x being empty.
=====================
Would have expected that catch to be caught ahead of writing a null in
place of the original file.
bash -v
suggests
RELEASE: 2.1
this on Linux Mint.
Regards
davidpbrown
Added tag(s) notabug.
Request was from
Eric Blake <eblake <at> redhat.com>
to
control <at> debbugs.gnu.org
.
(Fri, 23 Mar 2018 20:22:03 GMT)
Full text and
rfc822 format available.
Reply sent
to
Eric Blake <eblake <at> redhat.com>
:
You have taken responsibility.
(Fri, 23 Mar 2018 20:22:03 GMT)
Full text and
rfc822 format available.
Notification sent
to
openforum <at> davidpbrown.co.uk
:
bug acknowledged by developer.
(Fri, 23 Mar 2018 20:22:04 GMT)
Full text and
rfc822 format available.
Message #12 received at 30919-done <at> debbugs.gnu.org (full text, mbox):
tag 30919 notabug
thanks
On 03/23/2018 02:35 PM, davidpbrown wrote:
> Hi,
>
> Surprised that the error is noted but only after the file gets clobbered.
>
> Example:
> =====================
> echo "blah" > ./x
> grep -v 'foo' ./x > ./x
Unfortunately, there is nothing grep can do about this. The file was
already clobbered by your shell long before the shell even called exec()
to start grep.
I'm marking this as not a bug in grep's database, because there is
nothing grep can do about it. I'm sorry for your data loss, but this is
a naive beginner's mistake that multiple people have made for multiple
years.
The error message used in grep is reminiscent of the one used by 'sort
--o'; at least there, sort really does have a chance to warn you before
clobbering anything. But since 'grep -o' already means something
different than 'sort -o', I'm not sure if it is worth introducing a new
command line option, just so that:
grep -v foo --new-option-for-output=./x ./x
could properly warn (because in that style, it is grep, rather than the
shell, that would be opening stdout, and thus could avoid the
truncation). But even if we add a new option, it would take years
before it reaches common distros, and would still be a GNU extension not
present on other platforms, so you couldn't necessarily rely on it.
--
Eric Blake, Principal Software Engineer
Red Hat, Inc. +1-919-301-3266
Virtualization: qemu.org | libvirt.org
bug archived.
Request was from
Debbugs Internal Request <help-debbugs <at> gnu.org>
to
internal_control <at> debbugs.gnu.org
.
(Sat, 21 Apr 2018 11:24:04 GMT)
Full text and
rfc822 format available.
This bug report was last modified 7 years and 117 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.