~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/osutils.py

  • Committer: Parth Malwankar
  • Date: 2010-05-05 14:11:13 UTC
  • mfrom: (5211 +trunk)
  • mto: This revision was merged to the branch mainline in revision 5213.
  • Revision ID: parth.malwankar@gmail.com-20100505141113-c21oicoxzb3u6if6
merged in changes from trunk.

Show diffs side-by-side

added added

removed removed

Lines of Context:
17
17
import os
18
18
import re
19
19
import stat
20
 
from stat import (S_ISREG, S_ISDIR, S_ISLNK, ST_MODE, ST_SIZE,
21
 
                  S_ISCHR, S_ISBLK, S_ISFIFO, S_ISSOCK)
 
20
from stat import S_ISREG, S_ISDIR, S_ISLNK, ST_MODE, ST_SIZE
22
21
import sys
23
22
import time
24
23
import codecs
25
 
import warnings
26
24
 
27
25
from bzrlib.lazy_import import lazy_import
28
26
lazy_import(globals(), """
363
361
    return _win32_fixdrive(tempfile.mkdtemp(*args, **kwargs).replace('\\', '/'))
364
362
 
365
363
 
 
364
def _add_rename_error_details(e, old, new):
 
365
    new_e = OSError(e.errno, "failed to rename %s to %s: %s"
 
366
        % (old, new, e.strerror))
 
367
    new_e.filename = old
 
368
    new_e.to_filename = new
 
369
    return new_e
 
370
 
 
371
 
366
372
def _win32_rename(old, new):
367
373
    """We expect to be able to atomically replace 'new' with old.
368
374
 
370
376
    and then deleted.
371
377
    """
372
378
    try:
373
 
        fancy_rename(old, new, rename_func=os.rename, unlink_func=os.unlink)
 
379
        fancy_rename(old, new, rename_func=_wrapped_rename, unlink_func=os.unlink)
374
380
    except OSError, e:
375
381
        if e.errno in (errno.EPERM, errno.EACCES, errno.EBUSY, errno.EINVAL):
376
382
            # If we try to rename a non-existant file onto cwd, we get
381
387
        raise
382
388
 
383
389
 
 
390
def _wrapped_rename(old, new):
 
391
    """Rename a file or directory"""
 
392
    try:
 
393
        os.rename(old, new)
 
394
    except (IOError, OSError), e:
 
395
        # this is eventually called by all rename-like functions, so should 
 
396
        # catch all of them
 
397
        raise _add_rename_error_details(e, old, new)
 
398
 
 
399
 
384
400
def _mac_getcwd():
385
401
    return unicodedata.normalize('NFC', os.getcwdu())
386
402
 
391
407
realpath = _posix_realpath
392
408
pathjoin = os.path.join
393
409
normpath = os.path.normpath
 
410
rename = _wrapped_rename # overridden below on win32
394
411
getcwd = os.getcwdu
395
 
rename = os.rename
396
412
dirname = os.path.dirname
397
413
basename = os.path.basename
398
414
split = os.path.split
1132
1148
 
1133
1149
 
1134
1150
def relpath(base, path):
1135
 
    """Return path relative to base, or raise exception.
 
1151
    """Return path relative to base, or raise PathNotChild exception.
1136
1152
 
1137
1153
    The path may be either an absolute path or a path relative to the
1138
1154
    current working directory.
1140
1156
    os.path.commonprefix (python2.4) has a bad bug that it works just
1141
1157
    on string prefixes, assuming that '/u' is a prefix of '/u2'.  This
1142
1158
    avoids that problem.
 
1159
 
 
1160
    NOTE: `base` should not have a trailing slash otherwise you'll get
 
1161
    PathNotChild exceptions regardless of `path`.
1143
1162
    """
1144
1163
 
1145
1164
    if len(base) < MIN_ABS_PATHLENGTH: