mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-26 03:00:57 +00:00 
			
		
		
		
	Bring back gc() function
Renaming gc() to _gc() was a mistake since the better thing to do is put it behind the _COSMO_SOURCE macro. We need this change because I haven't wanted to use my amazing garbage collector ever since we renamed it. You now need to define _COSMO_SOURCE yourself when using amalgamation header and cosmocc users need to pass the -mcosmo flag to get the gc() function Some other issues relating to cancelation have been fixed along the way. We're also now putting cosmocc in a folder named `.cosmocc` so it can be more safely excluded by grep --exclude-dir=.cosmocc --exclude-dir=o etc.
This commit is contained in:
		
							parent
							
								
									6cb0354e19
								
							
						
					
					
						commit
						a4b455185b
					
				
					 280 changed files with 1362 additions and 1407 deletions
				
			
		
							
								
								
									
										8
									
								
								third_party/python/Python/import.c
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								third_party/python/Python/import.c
									
										
									
									
										vendored
									
									
								
							|  | @ -886,7 +886,7 @@ PyImport_ExecCodeModuleWithPathnames(const char *name, PyObject *co, | |||
|     else if (cpathobj != NULL) { | ||||
|         // cpathobj != NULL means cpathname != NULL
 | ||||
|         size_t cpathlen = strlen(cpathname); | ||||
|         char *pathname2 = _gc(strdup(cpathname)); | ||||
|         char *pathname2 = gc(strdup(cpathname)); | ||||
|         if (_endswith(pathname2, ".pyc")) | ||||
|         { | ||||
|             pathname2[cpathlen-2] = '\0'; // so now ends with .py
 | ||||
|  | @ -2152,7 +2152,7 @@ static PyObject *_imp_path_isdir(PyObject *module, PyObject *arg) { | |||
|   Py_ssize_t n; | ||||
|   const char *path; | ||||
|   if (!PyArg_Parse(arg, "z#:_path_isdir", &path, &n)) return 0; | ||||
|   if (path == NULL) path = _gc(getcwd(NULL, 0)); | ||||
|   if (path == NULL) path = gc(getcwd(NULL, 0)); | ||||
|   return _check_path_mode(path, S_IFDIR); | ||||
| } | ||||
| PyDoc_STRVAR(_imp_path_isdir_doc, "check if path is dir"); | ||||
|  | @ -2172,7 +2172,7 @@ static PyObject *_imp_calc_mtime_and_size(PyObject *module, PyObject *arg) { | |||
|   Py_ssize_t n; | ||||
|   const char *path; | ||||
|   if (!PyArg_Parse(arg, "z#:_calc_mtime_and_size", &path, &n)) return 0; | ||||
|   if (path == NULL) path = _gc(getcwd(NULL, 0)); | ||||
|   if (path == NULL) path = gc(getcwd(NULL, 0)); | ||||
|   if (stat(path, &stinfo)) | ||||
|     return PyTuple_Pack(2, PyLong_FromLong((long)-1), PyLong_FromLong((long)0)); | ||||
|   return PyTuple_Pack(2, PyLong_FromLong((long)stinfo.st_mtime), | ||||
|  | @ -2774,7 +2774,7 @@ static PyObject *CosmoImporter_find_spec(PyObject *cls, PyObject **args, | |||
|    */ | ||||
| 
 | ||||
|   newpathsize = sizeof(basepath) + cnamelen + sizeof("/__init__.pyc") + 1; | ||||
|   newpath = _gc(malloc(newpathsize)); | ||||
|   newpath = gc(malloc(newpathsize)); | ||||
|   bzero(newpath, newpathsize); | ||||
|   /* performing a memccpy sequence equivalent to:
 | ||||
|    * snprintf(newpath, newpathsize, "/zip/.python/%s.pyc", cname); */ | ||||
|  |  | |||
							
								
								
									
										2
									
								
								third_party/python/Python/marshal.c
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								third_party/python/Python/marshal.c
									
										
									
									
										vendored
									
									
								
							|  | @ -9,7 +9,7 @@ | |||
| #include "libc/calls/calls.h" | ||||
| #include "libc/calls/weirdtypes.h" | ||||
| #include "libc/mem/mem.h" | ||||
| #include "libc/mem/gc.internal.h" | ||||
| #include "libc/mem/gc.h" | ||||
| #include "third_party/python/Include/abstract.h" | ||||
| #include "third_party/python/Include/boolobject.h" | ||||
| #include "third_party/python/Include/code.h" | ||||
|  |  | |||
							
								
								
									
										2
									
								
								third_party/python/Python/sysmodule.c
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								third_party/python/Python/sysmodule.c
									
										
									
									
										vendored
									
									
								
							|  | @ -6,7 +6,7 @@ | |||
| ╚─────────────────────────────────────────────────────────────────────────────*/ | ||||
| #include "libc/calls/calls.h" | ||||
| #include "libc/dce.h" | ||||
| #include "libc/mem/gc.internal.h" | ||||
| #include "libc/mem/gc.h" | ||||
| #include "libc/mem/mem.h" | ||||
| #include "libc/nt/dll.h" | ||||
| #include "libc/nt/version.h" | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue