STINNER Victor added the comment:

I played with fullwrite.c and now think that the fix is incomplete. fwrite() 
may succeed to write data into the buffer, but you may get the error on 
fflush() or fclose().

Try attached fullwrite2.c: fwrite() succeed (written=len, errno=result=0), 
whereas fclose() fails. If you enable fflush(), it will also fail.

Output:
---
fwrite(hello
) => 6 bytes written/6 [errno=0, ferror=0]
fclose() => -1 [errno=28]
---

The complete fix is maybe to write fflush() before fclose(), or at least raise 
an exception if fclose() returns a non-zero result. Correctly, file.close() 
returns a number in case of an error...

But now comes the question of backward compatibility, may such change "break" 
applications? It's maybe a nice thing to "break" applications if it warns users 
that they are going to loose data (USB key full, cannot write the whole 
important document!).

----------
resolution: fixed -> 
status: closed -> open
Added file: http://bugs.python.org/file33178/fullwrite2.c

_______________________________________
Python tracker <rep...@bugs.python.org>
<http://bugs.python.org/issue17976>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to