summaryrefslogtreecommitdiff
path: root/Lib/distutils/dir_util.py
diff options
context:
space:
mode:
authorGreg Ward <gward@python.net>2000-09-30 17:47:17 +0000
committerGreg Ward <gward@python.net>2000-09-30 17:47:17 +0000
commit918d0943ff0f9bea5db309c26d347d64584417c4 (patch)
tree3c1d95187df7f84ab19be4f4e1e6b18090ead194 /Lib/distutils/dir_util.py
parentdb22cdfc34203ec8008688d27c3ad6e27a97e7aa (diff)
downloadcpython-918d0943ff0f9bea5db309c26d347d64584417c4.tar.gz
Andrew Kuchling: changed so the '_path_created' dictionary is keyed on
absolute pathnames; this lets it keep working in the face of chdir'ing around.
Diffstat (limited to 'Lib/distutils/dir_util.py')
-rw-r--r--Lib/distutils/dir_util.py13
1 files changed, 8 insertions, 5 deletions
diff --git a/Lib/distutils/dir_util.py b/Lib/distutils/dir_util.py
index 768cb4ebe7..a1578bed6a 100644
--- a/Lib/distutils/dir_util.py
+++ b/Lib/distutils/dir_util.py
@@ -44,7 +44,7 @@ def mkpath (name, mode=0777, verbose=0, dry_run=0):
created_dirs = []
if os.path.isdir(name) or name == '':
return created_dirs
- if _path_created.get(name):
+ if _path_created.get(os.path.abspath(name)):
return created_dirs
(head, tail) = os.path.split(name)
@@ -64,7 +64,9 @@ def mkpath (name, mode=0777, verbose=0, dry_run=0):
for d in tails:
#print "head = %s, d = %s: " % (head, d),
head = os.path.join(head, d)
- if _path_created.get(head):
+ abs_head = os.path.abspath(head)
+
+ if _path_created.get(abs_head):
continue
if verbose:
@@ -78,7 +80,7 @@ def mkpath (name, mode=0777, verbose=0, dry_run=0):
raise DistutilsFileError, \
"could not create '%s': %s" % (head, exc[-1])
- _path_created[head] = 1
+ _path_created[abs_head] = 1
return created_dirs
# mkpath ()
@@ -208,8 +210,9 @@ def remove_tree (directory, verbose=0, dry_run=0):
try:
apply(cmd[0], (cmd[1],))
# remove dir from cache if it's already there
- if _path_created.has_key(cmd[1]):
- del _path_created[cmd[1]]
+ abspath = os.path.abspath(cmd[1])
+ if _path_created.has_key(abspath):
+ del _path_created[abspath]
except (IOError, OSError), exc:
if verbose:
print grok_environment_error(