[Bug c/37785] New: printf + sleep = problems with output buffer

2008-10-09 Thread alexcastan at gmail dot com
PLATFORM

PC i386 + GNU/Linux Ubuntu Hardy 8.04 + GCC 4.2.3
Compiling and Linking options: none.

Excuse my poor English. (By the way, what is "Host triplet", "Target triplet",
"Build triplet"?)

BUG:

"printf" really prints at terminal when finds '\n' character. So if I have a
simple "printf" iteration without '\n' like this ...

  int n;
  for (n=10; n>=0; n--) {
printf("%d ", n);
sleep(1);
  };

... it doesn't works like expected. It just waits 10 seconds without printing
anything. After that prints whole line.

Another related problem with printf without '\n' and printf buffer using fork,
but I don't know if it is problem with printf or fork:

  int n, pid;
  for (n=10; n>=0; n--) {
printf("%d ", n);
sleep(1);
  };
  pid = fork();
  if (pid == -1)
printf("Error\n");
  else 
if (pid == 0)
  printf("I'm the child\n");
else 
  printf("I'm the parent\n");

it prints TWO times   10 9 8 7 6 5 4 3 2 1 0
It is not that executes two times, but if the fork send again the buffer to the
screen.


-- 
   Summary: printf + sleep = problems with output buffer
   Product: gcc
   Version: 4.2.3
Status: UNCONFIRMED
      Severity: normal
  Priority: P3
 Component: c
AssignedTo: unassigned at gcc dot gnu dot org
ReportedBy: alexcastan at gmail dot com


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=37785



[Bug c/37785] printf without '\n' + sleep = problems with output buffer

2008-10-09 Thread alexcastan at gmail dot com


--- Comment #3 from alexcastan at gmail dot com  2008-10-09 20:24 ---
Then the second problem it is also the normal behavior. The fork()
makes child inherit the unprinted parent buffer, then two similar buffers get
print later.

  10 9 8 7 6 5 4 3 2 1 0   I'm the child
  10 9 8 7 6 5 4 3 2 1 0   I'm the parent


-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=37785