mirror of
				https://github.com/python/cpython.git
				synced 2025-10-30 18:07:37 +00:00 
			
		
		
		
	 24e837f231
			
		
	
	
		24e837f231
		
	
	
	
	
		
			
			add private method to enum to support replacing global constants with Enum members: - search for candidate constants via supplied filter - create new enum class and members - insert enum class and replace constants with members via supplied module name - replace __reduce_ex__ with function that returns member name, so previous Python versions can unpickle modify IntEnum classes to use new method
		
			
				
	
	
		
			79 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import _signal
 | |
| from _signal import *
 | |
| from functools import wraps as _wraps
 | |
| from enum import IntEnum as _IntEnum
 | |
| 
 | |
| _globals = globals()
 | |
| 
 | |
| _IntEnum._convert(
 | |
|         'Signals', __name__,
 | |
|         lambda name:
 | |
|             name.isupper()
 | |
|             and (name.startswith('SIG') and not name.startswith('SIG_'))
 | |
|             or name.startswith('CTRL_'))
 | |
| 
 | |
| _IntEnum._convert(
 | |
|         'Handlers', __name__,
 | |
|         lambda name: name in ('SIG_DFL', 'SIG_IGN'))
 | |
| 
 | |
| if 'pthread_sigmask' in _globals:
 | |
|     _IntEnum._convert(
 | |
|             'Sigmasks', __name__,
 | |
|             lambda name: name in ('SIG_BLOCK', 'SIG_UNBLOCK', 'SIG_SETMASK'))
 | |
| 
 | |
| 
 | |
| def _int_to_enum(value, enum_klass):
 | |
|     """Convert a numeric value to an IntEnum member.
 | |
|     If it's not a known member, return the numeric value itself.
 | |
|     """
 | |
|     try:
 | |
|         return enum_klass(value)
 | |
|     except ValueError:
 | |
|         return value
 | |
| 
 | |
| 
 | |
| def _enum_to_int(value):
 | |
|     """Convert an IntEnum member to a numeric value.
 | |
|     If it's not a IntEnum member return the value itself.
 | |
|     """
 | |
|     try:
 | |
|         return int(value)
 | |
|     except (ValueError, TypeError):
 | |
|         return value
 | |
| 
 | |
| 
 | |
| @_wraps(_signal.signal)
 | |
| def signal(signalnum, handler):
 | |
|     handler = _signal.signal(_enum_to_int(signalnum), _enum_to_int(handler))
 | |
|     return _int_to_enum(handler, Handlers)
 | |
| 
 | |
| 
 | |
| @_wraps(_signal.getsignal)
 | |
| def getsignal(signalnum):
 | |
|     handler = _signal.getsignal(signalnum)
 | |
|     return _int_to_enum(handler, Handlers)
 | |
| 
 | |
| 
 | |
| if 'pthread_sigmask' in _globals:
 | |
|     @_wraps(_signal.pthread_sigmask)
 | |
|     def pthread_sigmask(how, mask):
 | |
|         sigs_set = _signal.pthread_sigmask(how, mask)
 | |
|         return set(_int_to_enum(x, Signals) for x in sigs_set)
 | |
|     pthread_sigmask.__doc__ = _signal.pthread_sigmask.__doc__
 | |
| 
 | |
| 
 | |
| if 'sigpending' in _globals:
 | |
|     @_wraps(_signal.sigpending)
 | |
|     def sigpending():
 | |
|         sigs = _signal.sigpending()
 | |
|         return set(_int_to_enum(x, Signals) for x in sigs)
 | |
| 
 | |
| 
 | |
| if 'sigwait' in _globals:
 | |
|     @_wraps(_signal.sigwait)
 | |
|     def sigwait(sigset):
 | |
|         retsig = _signal.sigwait(sigset)
 | |
|         return _int_to_enum(retsig, Signals)
 | |
|     sigwait.__doc__ = _signal.sigwait
 | |
| 
 | |
| del _globals, _wraps
 |