mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 10:44:55 +00:00 
			
		
		
		
	#11910: merge with 3.1.
This commit is contained in:
		
						commit
						313fa9d365
					
				
					 1 changed files with 8 additions and 4 deletions
				
			
		|  | @ -92,12 +92,14 @@ def import_module(name, deprecated=False): | |||
| def _save_and_remove_module(name, orig_modules): | ||||
|     """Helper function to save and remove a module from sys.modules | ||||
| 
 | ||||
|        Return value is True if the module was in sys.modules and | ||||
|        False otherwise.""" | ||||
|        Return True if the module was in sys.modules, False otherwise. | ||||
|        Raise ImportError if the module can't be imported.""" | ||||
|     saved = True | ||||
|     try: | ||||
|         orig_modules[name] = sys.modules[name] | ||||
|     except KeyError: | ||||
|         # try to import the module and raise an error if it can't be imported | ||||
|         __import__(name) | ||||
|         saved = False | ||||
|     else: | ||||
|         del sys.modules[name] | ||||
|  | @ -107,8 +109,7 @@ def _save_and_remove_module(name, orig_modules): | |||
| def _save_and_block_module(name, orig_modules): | ||||
|     """Helper function to save and block a module in sys.modules | ||||
| 
 | ||||
|        Return value is True if the module was in sys.modules and | ||||
|        False otherwise.""" | ||||
|        Return True if the module was in sys.modules, False otherwise.""" | ||||
|     saved = True | ||||
|     try: | ||||
|         orig_modules[name] = sys.modules[name] | ||||
|  | @ -124,6 +125,7 @@ def import_fresh_module(name, fresh=(), blocked=(), deprecated=False): | |||
|     the sys.modules cache is restored to its original state. | ||||
| 
 | ||||
|     Modules named in fresh are also imported anew if needed by the import. | ||||
|     If one of these modules can't be imported, None is returned. | ||||
| 
 | ||||
|     Importing of modules named in blocked is prevented while the fresh import | ||||
|     takes place. | ||||
|  | @ -145,6 +147,8 @@ def import_fresh_module(name, fresh=(), blocked=(), deprecated=False): | |||
|                 if not _save_and_block_module(blocked_name, orig_modules): | ||||
|                     names_to_remove.append(blocked_name) | ||||
|             fresh_module = importlib.import_module(name) | ||||
|         except ImportError: | ||||
|             fresh_module = None | ||||
|         finally: | ||||
|             for orig_name, module in orig_modules.items(): | ||||
|                 sys.modules[orig_name] = module | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Ezio Melotti
						Ezio Melotti