mirror of
https://github.com/servo/servo.git
synced 2025-08-07 06:25:32 +01:00
Auto merge of #20244 - servo:jdm-patch-10, r=SimonSapin
Ensure readonly files can be removed on Windows. This is based off of https://bugs.python.org/issue19643. At worst, it makes our deletion function more robust and doesn't help with the ongoing windows CI problems. <!-- Reviewable:start --> --- This change is [<img src="https://reviewable.io/review_button.svg" height="34" align="absmiddle" alt="Reviewable"/>](https://reviewable.io/reviews/servo/servo/20244) <!-- Reviewable:end -->
This commit is contained in:
commit
f1338d3df8
2 changed files with 10 additions and 1 deletions
|
@ -16,6 +16,7 @@ import os.path as path
|
||||||
import re
|
import re
|
||||||
import subprocess
|
import subprocess
|
||||||
import sys
|
import sys
|
||||||
|
import traceback
|
||||||
import urllib2
|
import urllib2
|
||||||
import glob
|
import glob
|
||||||
|
|
||||||
|
@ -318,6 +319,7 @@ class MachCommands(CommandBase):
|
||||||
try:
|
try:
|
||||||
delete(crate_path)
|
delete(crate_path)
|
||||||
except:
|
except:
|
||||||
|
print(traceback.format_exc())
|
||||||
print("Delete %s failed!" % crate_path)
|
print("Delete %s failed!" % crate_path)
|
||||||
else:
|
else:
|
||||||
print("Would remove `{}`{} package from {}".format(*print_msg))
|
print("Would remove `{}`{} package from {}".format(*print_msg))
|
||||||
|
|
|
@ -14,6 +14,7 @@ import os.path
|
||||||
import platform
|
import platform
|
||||||
import shutil
|
import shutil
|
||||||
from socket import error as socket_error
|
from socket import error as socket_error
|
||||||
|
import stat
|
||||||
import StringIO
|
import StringIO
|
||||||
import sys
|
import sys
|
||||||
import zipfile
|
import zipfile
|
||||||
|
@ -35,9 +36,15 @@ else:
|
||||||
URLOPEN_KWARGS = {}
|
URLOPEN_KWARGS = {}
|
||||||
|
|
||||||
|
|
||||||
|
def remove_readonly(func, path, _):
|
||||||
|
"Clear the readonly bit and reattempt the removal"
|
||||||
|
os.chmod(path, stat.S_IWRITE)
|
||||||
|
func(path)
|
||||||
|
|
||||||
|
|
||||||
def delete(path):
|
def delete(path):
|
||||||
if os.path.isdir(path) and not os.path.islink(path):
|
if os.path.isdir(path) and not os.path.islink(path):
|
||||||
shutil.rmtree(path)
|
shutil.rmtree(path, onerror=remove_readonly)
|
||||||
else:
|
else:
|
||||||
os.remove(path)
|
os.remove(path)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue