Sindbad~EG File Manager
"""High-level file operations."""
import errno
import logging
import shutil
logger = logging.getLogger(__name__)
def rmtree(path, ignore_errors=False, onerror=None, *, max_tries=3):
"""More robust shutil.rmtree.
Retry on "Directory not empty" race condition:
https://github.com/ansible/ansible/issues/34335#issuecomment-362995700
"""
for i in range(1, max_tries + 1):
try:
return shutil.rmtree(path, ignore_errors, onerror)
except OSError as e:
if i == max_tries or e.errno not in [
errno.EEXIST,
errno.ENOTEMPTY,
]:
raise
# Got "Directory not empty" and attempts are not exhausted yet
logger.warning("Can't remove %s tree, reason: %s", path, e)
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists