~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/atomicfile.py

Merge in format-5 work - release bzr 0.1rc1.

Show diffs side-by-side

added added

removed removed

Lines of Context:
17
17
 
18
18
 
19
19
from warnings import warn
20
 
 
 
20
from osutils import rename
21
21
 
22
22
class AtomicFile(object):
23
23
    """A file that does an atomic-rename to move into place.
65
65
        self.f.close()
66
66
        self.f = None
67
67
        
68
 
        if sys.platform == 'win32':
69
 
            # windows cannot rename over an existing file
70
 
            try:
71
 
                os.remove(self.realfilename)
72
 
            except OSError, e:
73
 
                import errno
74
 
                if e.errno != errno.ENOENT:
75
 
                    raise
76
 
                
77
 
        os.rename(self.tmpfilename, self.realfilename)
 
68
        rename(self.tmpfilename, self.realfilename)
78
69
 
79
70
 
80
71
    def abort(self):
97
88
 
98
89
 
99
90
    def __del__(self):
100
 
        if not self.closed:
 
91
        if hasattr(self, 'closed') and not self.closed:
101
92
            warn("%r leaked" % self)
102
93