Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > gnu.bash.bug > #14635 > unrolled thread

Re: bash sockets: printf \x0a does TCP fragmentation

Started bydirk+bash@testssl.sh
First post2018-09-22 12:49 +0200
Last post2018-09-22 12:49 +0200
Articles 1 — 1 participant

Back to article view | Back to gnu.bash.bug

This discussion starts older than the indexed window; earlier articles aren't shown. The article labeled Started by below is the oldest one visible, not the original post.


Contents

  Re: bash sockets: printf \x0a does TCP fragmentation dirk+bash@testssl.sh - 2018-09-22 12:49 +0200

#14635 — Re: bash sockets: printf \x0a does TCP fragmentation

Fromdirk+bash@testssl.sh
Date2018-09-22 12:49 +0200
SubjectRe: bash sockets: printf \x0a does TCP fragmentation
Message-ID<mailman.1135.1537613418.1284.bug-bash@gnu.org>

On 9/22/18 12:38 PM, Ilkka Virta wrote:
> On 22.9. 02:34, Chet Ramey wrote:
>> Newline? It's probably that stdout is line-buffered and the newline causes
>> a flush, which results in a write(2).
> 
> Mostly out of curiosity, what kind of buffering logic does Bash (or the builtin
> printf in particular) use? It doesn't seem to be the usual stdio logic where you get
> line-buffering if printing to a terminal and block buffering otherwise. I get a
> distinct write per line even if the stdout of Bash itself is redirected to say
> /dev/null or a pipe:
> 
>  $ strace -etrace=write bash -c 'printf "foo\nbar\n"' > /dev/null
>  write(1, "foo\n", 4)                    = 4
>  write(1, "bar\n", 4)                    = 4
>  +++ exited with 0 +++

Oh. But thanks anyway!

coreutils in fact does it in one shot as you indicated.


Dirk


[toc] | [standalone]


Back to top | Article view | gnu.bash.bug


csiph-web