mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-25 10:40:57 +00:00 
			
		
		
		
	Tell _frozen_importlib to consider bytecode first (#248)
This commit is contained in:
		
							parent
							
								
									c70422586a
								
							
						
					
					
						commit
						ace523c79b
					
				
					 7 changed files with 2896 additions and 2887 deletions
				
			
		|  | @ -1364,7 +1364,7 @@ def _get_supported_file_loaders(): | |||
|     extensions = ExtensionFileLoader, _imp.extension_suffixes() | ||||
|     source = SourceFileLoader, SOURCE_SUFFIXES | ||||
|     bytecode = SourcelessFileLoader, BYTECODE_SUFFIXES | ||||
|     return [extensions, source, bytecode] | ||||
|     return [extensions, bytecode, source] | ||||
| 
 | ||||
| 
 | ||||
| def _setup(_bootstrap_module): | ||||
|  |  | |||
							
								
								
									
										3
									
								
								third_party/python/Lib/site.py
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								third_party/python/Lib/site.py
									
										
									
									
										vendored
									
									
								
							|  | @ -123,6 +123,9 @@ def removeduppaths(): | |||
|         # Filter out duplicate paths (on case-insensitive file systems also | ||||
|         # if they only differ in case); turn relative paths into absolute | ||||
|         # paths. | ||||
|         if dir.startswith("zip!"): # don't absolutize, look within the APE! | ||||
|             L.append(dir) | ||||
|             continue | ||||
|         dir, dircase = makepath(dir) | ||||
|         if not dircase in known_paths: | ||||
|             L.append(dir) | ||||
|  |  | |||
							
								
								
									
										8
									
								
								third_party/python/Modules/getpath.c
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								third_party/python/Modules/getpath.c
									
										
									
									
										vendored
									
									
								
							|  | @ -120,7 +120,8 @@ wchar_t *Py_GetProgramName(void); | |||
| static wchar_t prefix[MAXPATHLEN+1]; | ||||
| static wchar_t exec_prefix[MAXPATHLEN+1]; | ||||
| static wchar_t progpath[MAXPATHLEN+1]; | ||||
| static wchar_t *module_search_path = NULL; | ||||
| static wchar_t limited_search_path[] = L"zip!.python"; | ||||
| static wchar_t *module_search_path = limited_search_path; | ||||
| 
 | ||||
| /* Get file status. Encode the path to the locale encoding. */ | ||||
| 
 | ||||
|  | @ -466,7 +467,6 @@ search_for_exec_prefix(wchar_t *argv0_path, wchar_t *home, | |||
| static void | ||||
| calculate_path(void) | ||||
| { | ||||
| #if 0 | ||||
|     static wchar_t delimiter[2] = {DELIM, '\0'}; | ||||
|     static wchar_t separator[2] = {SEP, '\0'}; | ||||
|     /* ignore PYTHONPATH/PYTHONHOME for now */ | ||||
|  | @ -608,10 +608,6 @@ calculate_path(void) | |||
|     /* And publish the results */ | ||||
|     module_search_path = buf; | ||||
|     // printf("%ls\n", buf);
 | ||||
| #else | ||||
|     module_search_path = L"zip!.python/"; | ||||
|     /* module_search_path = L"third_party/python/Lib/"; */ | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
| /* External interface */ | ||||
|  |  | |||
							
								
								
									
										2
									
								
								third_party/python/Python/importlib.inc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								third_party/python/Python/importlib.inc
									
										
									
									
										vendored
									
									
								
							|  | @ -8,7 +8,7 @@ | |||
| 
 | ||||
| /* | ||||
|  * Auto-generated by | ||||
|  * m/third_party/python/freeze.com \ | ||||
|  * o/third_party/python/freeze.com \ | ||||
|  *   third_party/python/Lib/importlib/_bootstrap.py \ | ||||
|  *   third_party/python/Python/importlib.inc | ||||
|  */ | ||||
|  |  | |||
|  | @ -8,7 +8,7 @@ | |||
| 
 | ||||
| /* | ||||
|  * Auto-generated by | ||||
|  * m/third_party/python/freeze.com \ | ||||
|  * o/third_party/python/freeze.com \ | ||||
|  *   third_party/python/Lib/importlib/_bootstrap_external.py \ | ||||
|  *   third_party/python/Python/importlib_external.inc | ||||
|  */ | ||||
|  | @ -2289,7 +2289,7 @@ const unsigned char _Py_M__importlib_external[] = { | |||
|     0,0,0,0,0,0,0,3,0,0,0,3,0,0,0,67, | ||||
|     0,0,0,115,38,0,0,0,116,0,116,1,106,2,131,0, | ||||
|     102,2,125,0,116,3,116,4,102,2,125,1,116,5,116,6, | ||||
|     102,2,125,2,124,0,124,1,124,2,103,3,83,0,41,1, | ||||
|     102,2,125,2,124,0,124,2,124,1,103,3,83,0,41,1, | ||||
|     122,95,82,101,116,117,114,110,115,32,97,32,108,105,115,116, | ||||
|     32,111,102,32,102,105,108,101,45,98,97,115,101,100,32,109, | ||||
|     111,100,117,108,101,32,108,111,97,100,101,114,115,46,10,10, | ||||
|  |  | |||
							
								
								
									
										11
									
								
								third_party/python/Python/pylifecycle.c
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								third_party/python/Python/pylifecycle.c
									
										
									
									
										vendored
									
									
								
							|  | @ -307,6 +307,17 @@ import_init(PyInterpreterState *interp, PyObject *sysmod) | |||
| 
 | ||||
|     /* just add zip!.python/ to sys.path */ | ||||
|     /* _PyImportZip_Init(); */ | ||||
|     PyImport_ImportModule("_codecs"); | ||||
|     PyImport_ImportModule("_collections"); | ||||
|     PyImport_ImportModule("_functools"); | ||||
|     PyImport_ImportModule("_heapq"); | ||||
|     PyImport_ImportModule("_locale"); | ||||
|     PyImport_ImportModule("_operator"); | ||||
|     PyImport_ImportModule("_signal"); | ||||
|     PyImport_ImportModule("_sre"); | ||||
|     PyImport_ImportModule("_stat"); | ||||
|     PyImport_ImportModule("errno"); | ||||
|     PyImport_ImportModule("itertools"); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										5753
									
								
								third_party/python/python-stdlib.mk
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										5753
									
								
								third_party/python/python-stdlib.mk
									
										
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue