Jim Meyering wrote:
> Pádraig Brady <[EMAIL PROTECTED]> wrote:
>> dd handles skip weirdly
>>
>> disk=/dev/sda8
>> dd if=$disk bs=8M count=1 skip=1000 of=/dev/null  #ok
>> dd if=$disk bs=8M count=1 skip=1000K of=/dev/null #reads whole disk! as seek 
>> fails
>>
>> I had a 10s look at the source and noticed a comment
>> saying POSIX doesn't specify what we should do when
>> skipping past the end of input. For seekable files though,
>> reading the whole thing is unexpected to me at least.
>> I would expect it to do:
>>
>> if (seekable && !seek(skip_len))
>>     exit(EXIT_FAILURE);
> 
> Thanks, but the existing behavior is deliberate, and IMHO, necessary.
> 
> skip=N is required to try to seek, and failing that, position
> the read pointer by calling read.  That is so it works on
> e.g., redirected stdin as well as on regular files.
redirected stdin is seekable.
Note the logic I presented above.

Pádraig.


_______________________________________________
Bug-coreutils mailing list
Bug-coreutils@gnu.org
http://lists.gnu.org/mailman/listinfo/bug-coreutils

Reply via email to