You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Python
		
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Python
		
	
"""
 | 
						|
requests._internal_utils
 | 
						|
~~~~~~~~~~~~~~
 | 
						|
 | 
						|
Provides utility functions that are consumed internally by Requests
 | 
						|
which depend on extremely few external helpers (such as compat)
 | 
						|
"""
 | 
						|
import re
 | 
						|
 | 
						|
from .compat import builtin_str
 | 
						|
 | 
						|
_VALID_HEADER_NAME_RE_BYTE = re.compile(rb"^[^:\s][^:\r\n]*$")
 | 
						|
_VALID_HEADER_NAME_RE_STR = re.compile(r"^[^:\s][^:\r\n]*$")
 | 
						|
_VALID_HEADER_VALUE_RE_BYTE = re.compile(rb"^\S[^\r\n]*$|^$")
 | 
						|
_VALID_HEADER_VALUE_RE_STR = re.compile(r"^\S[^\r\n]*$|^$")
 | 
						|
 | 
						|
_HEADER_VALIDATORS_STR = (_VALID_HEADER_NAME_RE_STR, _VALID_HEADER_VALUE_RE_STR)
 | 
						|
_HEADER_VALIDATORS_BYTE = (_VALID_HEADER_NAME_RE_BYTE, _VALID_HEADER_VALUE_RE_BYTE)
 | 
						|
HEADER_VALIDATORS = {
 | 
						|
    bytes: _HEADER_VALIDATORS_BYTE,
 | 
						|
    str: _HEADER_VALIDATORS_STR,
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
def to_native_string(string, encoding="ascii"):
 | 
						|
    """Given a string object, regardless of type, returns a representation of
 | 
						|
    that string in the native string type, encoding and decoding where
 | 
						|
    necessary. This assumes ASCII unless told otherwise.
 | 
						|
    """
 | 
						|
    if isinstance(string, builtin_str):
 | 
						|
        out = string
 | 
						|
    else:
 | 
						|
        out = string.decode(encoding)
 | 
						|
 | 
						|
    return out
 | 
						|
 | 
						|
 | 
						|
def unicode_is_ascii(u_string):
 | 
						|
    """Determine if unicode string only contains ASCII characters.
 | 
						|
 | 
						|
    :param str u_string: unicode string to check. Must be unicode
 | 
						|
        and not Python 2 `str`.
 | 
						|
    :rtype: bool
 | 
						|
    """
 | 
						|
    assert isinstance(u_string, str)
 | 
						|
    try:
 | 
						|
        u_string.encode("ascii")
 | 
						|
        return True
 | 
						|
    except UnicodeEncodeError:
 | 
						|
        return False
 |