I am seeing some odd behavior using Cygwin x64 2.9.0 on Windows 10 Pro x64. The command I am attempting to run is the following:
tac <file> | grep -q -m1 -F "literal string"
The above command succeeds on all small files that I throw at it (small means <= 15kB). It also succeeds if the final occurrence of literal string
is near the start of the file (e.g., literal string
appears near the top of the file and nowhere else). Finally, it also succeeds when neither of the {-q
, -m1
} flags is passed to the grep
command.
However, when the file is around 680kB, and the literal string
appears near the end of the file, then the tac
command prints "tac: write error" to STDERR. Despite this error, the command appears to have succeeded, printing the matching line to output (when the -q
flag is omitted) and getting the appropriate return value from grep
.
Further testing has revealed that this same error occurs when using cat
, except the literal string
must appear near the start of the file to generate the error, and the generated error is "cat: write error: No space left on device".
Note that this only occurs if at least one of the {-m1
, -q
} options is passed to the grep
command, the match is near the first processed line of the file (for cat
it is near the beginning, for tac
it is near the end), and the file is large.
I have run the df
command, and it reports 14 MB available on the Cygwin drive, with 60 GiB free on the actual disk. I know I could simply redirect STDERR to the NUL device, but that seems like a hacky work-around. Does anyone know how to fix this properly?
BEGIN EDIT
I found another report of the same error from May 2017, but no solution was presented. The OP of the other post does indicate that he thinks this is a pipe buffer size limitation (perhaps on Windows, perhaps in Cygwin).