£Á°èZ¨Ä…–K§‚«“ô4“ÒÙ´dîfUÙÃÅ WKbyʦ•ꎅȮFÒ¿ÊÎóCozá¬S@6{Í:›œêZÌ:Š•_%:¢¾¾~;‘Ã~芩ÊǍí`ÔÑ©ú뙵'5I¿fš×WO%ø9¾«¾DK|€ùÍD”Ýs]nHÕ¶êםӼ㞪éUWŸÈË%DÒÕ¬ï‘]/Åcx ‰ï2ß]ä6G[]S£Ôϯrs{úëóµmÒï#UQxo·õÞCe]"±/aÙ&Eã4ú9Jé_ÞåëdãöKë)AÞ ¯¹ægƒÛowЍø^d™ý½ßB7áyMä9ÜÖUã !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! """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)