You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					74 lines
				
				1.4 KiB
			
		
		
			
		
	
	
					74 lines
				
				1.4 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								# SPDX-License-Identifier: MIT
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								"""
							 | 
						||
| 
								 | 
							
								Commonly used hooks for on_setattr.
							 | 
						||
| 
								 | 
							
								"""
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								from . import _config
							 | 
						||
| 
								 | 
							
								from .exceptions import FrozenAttributeError
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								def pipe(*setters):
							 | 
						||
| 
								 | 
							
								    """
							 | 
						||
| 
								 | 
							
								    Run all *setters* and return the return value of the last one.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    .. versionadded:: 20.1.0
							 | 
						||
| 
								 | 
							
								    """
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    def wrapped_pipe(instance, attrib, new_value):
							 | 
						||
| 
								 | 
							
								        rv = new_value
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        for setter in setters:
							 | 
						||
| 
								 | 
							
								            rv = setter(instance, attrib, rv)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return rv
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return wrapped_pipe
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								def frozen(_, __, ___):
							 | 
						||
| 
								 | 
							
								    """
							 | 
						||
| 
								 | 
							
								    Prevent an attribute to be modified.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    .. versionadded:: 20.1.0
							 | 
						||
| 
								 | 
							
								    """
							 | 
						||
| 
								 | 
							
								    raise FrozenAttributeError()
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								def validate(instance, attrib, new_value):
							 | 
						||
| 
								 | 
							
								    """
							 | 
						||
| 
								 | 
							
								    Run *attrib*'s validator on *new_value* if it has one.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    .. versionadded:: 20.1.0
							 | 
						||
| 
								 | 
							
								    """
							 | 
						||
| 
								 | 
							
								    if _config._run_validators is False:
							 | 
						||
| 
								 | 
							
								        return new_value
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    v = attrib.validator
							 | 
						||
| 
								 | 
							
								    if not v:
							 | 
						||
| 
								 | 
							
								        return new_value
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    v(instance, attrib, new_value)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return new_value
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								def convert(instance, attrib, new_value):
							 | 
						||
| 
								 | 
							
								    """
							 | 
						||
| 
								 | 
							
								    Run *attrib*'s converter -- if it has one --  on *new_value* and return the
							 | 
						||
| 
								 | 
							
								    result.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    .. versionadded:: 20.1.0
							 | 
						||
| 
								 | 
							
								    """
							 | 
						||
| 
								 | 
							
								    c = attrib.converter
							 | 
						||
| 
								 | 
							
								    if c:
							 | 
						||
| 
								 | 
							
								        return c(new_value)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return new_value
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								# Sentinel for disabling class-wide *on_setattr* hooks for certain attributes.
							 | 
						||
| 
								 | 
							
								# autodata stopped working, so the docstring is inlined in the API docs.
							 | 
						||
| 
								 | 
							
								NO_OP = object()
							 |