mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 18:54:53 +00:00 
			
		
		
		
	Issue #23694: Enhance _Py_open(), it now raises exceptions
* _Py_open() now raises exceptions on error. If open() fails, it raises an OSError with the filename. * _Py_open() now releases the GIL while calling open() * Add _Py_open_noraise() when _Py_open() cannot be used because the GIL is not held
This commit is contained in:
		
							parent
							
								
									6562b29e13
								
							
						
					
					
						commit
						a555cfcb73
					
				
					 8 changed files with 71 additions and 45 deletions
				
			
		|  | @ -111,7 +111,7 @@ dev_urandom_noraise(unsigned char *buffer, Py_ssize_t size) | |||
| 
 | ||||
|     assert (0 < size); | ||||
| 
 | ||||
|     fd = _Py_open("/dev/urandom", O_RDONLY); | ||||
|     fd = _Py_open_noraise("/dev/urandom", O_RDONLY); | ||||
|     if (fd < 0) | ||||
|         Py_FatalError("Failed to open /dev/urandom"); | ||||
| 
 | ||||
|  | @ -158,17 +158,13 @@ dev_urandom_python(char *buffer, Py_ssize_t size) | |||
|     if (urandom_cache.fd >= 0) | ||||
|         fd = urandom_cache.fd; | ||||
|     else { | ||||
|         Py_BEGIN_ALLOW_THREADS | ||||
|         fd = _Py_open("/dev/urandom", O_RDONLY); | ||||
|         Py_END_ALLOW_THREADS | ||||
|         if (fd < 0) | ||||
|         { | ||||
|         if (fd < 0) { | ||||
|             if (errno == ENOENT || errno == ENXIO || | ||||
|                 errno == ENODEV || errno == EACCES) | ||||
|                 PyErr_SetString(PyExc_NotImplementedError, | ||||
|                                 "/dev/urandom (or equivalent) not found"); | ||||
|             else | ||||
|                 PyErr_SetFromErrno(PyExc_OSError); | ||||
|             /* otherwise, keep the OSError exception raised by _Py_open() */ | ||||
|             return -1; | ||||
|         } | ||||
|         if (urandom_cache.fd >= 0) { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Victor Stinner
						Victor Stinner