mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Improved performance of utils.html.escape().
This commit is contained in:
		| @@ -1,4 +1,5 @@ | ||||
| import copy | ||||
| import itertools | ||||
| import operator | ||||
| from functools import total_ordering, wraps | ||||
|  | ||||
| @@ -189,7 +190,7 @@ def keep_lazy(*resultclasses): | ||||
|  | ||||
|         @wraps(func) | ||||
|         def wrapper(*args, **kwargs): | ||||
|             for arg in list(args) + list(kwargs.values()): | ||||
|             for arg in itertools.chain(args, kwargs.values()): | ||||
|                 if isinstance(arg, Promise): | ||||
|                     break | ||||
|             else: | ||||
|   | ||||
| @@ -30,6 +30,14 @@ simple_url_re = re.compile(r'^https?://\[?\w', re.IGNORECASE) | ||||
| simple_url_2_re = re.compile(r'^www\.|^(?!http)\w[^@]+\.(com|edu|gov|int|mil|net|org)($|/.*)$', re.IGNORECASE) | ||||
| simple_email_re = re.compile(r'^\S+@\S+\.\S+$') | ||||
|  | ||||
| _html_escapes = { | ||||
|     ord('&'): '&', | ||||
|     ord('<'): '<', | ||||
|     ord('>'): '>', | ||||
|     ord('"'): '"', | ||||
|     ord("'"): ''', | ||||
| } | ||||
|  | ||||
|  | ||||
| @keep_lazy(str, SafeText) | ||||
| def escape(text): | ||||
| @@ -41,10 +49,7 @@ def escape(text): | ||||
|     This may result in double-escaping. If this is a concern, use | ||||
|     conditional_escape() instead. | ||||
|     """ | ||||
|     return mark_safe( | ||||
|         str(text).replace('&', '&').replace('<', '<') | ||||
|         .replace('>', '>').replace('"', '"').replace("'", ''') | ||||
|     ) | ||||
|     return mark_safe(str(text).translate(_html_escapes)) | ||||
|  | ||||
|  | ||||
| _js_escapes = { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user