Milko Krachounov <pyt...@milko.3mhz.net> added the comment:

I have a class for overwriting files "properly" that I use in three of my 
projects. It aims to be atomic as possible, supports creating backups, but it 
doesn't have functions to set or retain permissions when requested (which might 
be desirable if such a function is added to stdlib). I'd give it here for 
reference and ideas.

- It's a context manager acting like a normal file object so you can use it 
with e.g. json.dump. In CM mode, if an error is caught, you end up with the old 
file automatically. If you use it as a file, the 'close' method has a 'cancel' 
argument to achieve the same.
- Normal overwrite on POSIX uses flush, fsync, rename as it should.
- Since fsync doesn't work on Mac OS X, it takes care of calling the Mac OS X 
specific F_FULLFSYNC fcntl.
- On POSIX, if a backup is requested, an attempt is made to do it with a 
hardlink, otherwise do two renames (killing the atomicity). Maybe a copy with 
shutil would be a better choice though.
- On Windows it uses two renames - the old file is backed up to a temporary 
name, and then the new file is renamed over it. If a backup wasn't requested, 
the temporary name is deleted.

I also have a simple unit test for it, but I've ran it on POSIX only.

Here's the part of the code that does the open/close part:
http://bazaar.launchpad.net/~exabyte/blackherd/async-refactor/view/61/blackherd/misc.py#L498

And the unit test:
http://bazaar.launchpad.net/~exabyte/blackherd/async-refactor/view/61/tests/test_misc.py#L473

I hope that's useful.

----------
nosy: +milko.krachounov

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

Reply via email to