mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #4657 -- Fixed an error in an edge case of the urlizetrunc filter.
Thanks, SmileyChris. git-svn-id: http://code.djangoproject.com/svn/django/trunk@5513 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -53,16 +53,18 @@ def fix_ampersands(value): | |||||||
|  |  | ||||||
| def urlize(text, trim_url_limit=None, nofollow=False): | def urlize(text, trim_url_limit=None, nofollow=False): | ||||||
|     """ |     """ | ||||||
|     Converts any URLs in text into clickable links. Works on http://, https:// and |     Converts any URLs in text into clickable links. Works on http://, https:// | ||||||
|     www. links. Links can have trailing punctuation (periods, commas, close-parens) |     and www. links. Links can have trailing punctuation (periods, commas, | ||||||
|     and leading punctuation (opening parens) and it'll still do the right thing. |     close-parens) and leading punctuation (opening parens) and it'll still do | ||||||
|  |     the right thing. | ||||||
|  |  | ||||||
|     If trim_url_limit is not None, the URLs in link text will be limited to |     If trim_url_limit is not None, the URLs in link text longer than this limit | ||||||
|     trim_url_limit characters. |     will truncated to trim_url_limit-3 characters and appended with an elipsis. | ||||||
|  |  | ||||||
|     If nofollow is True, the URLs in link text will get a rel="nofollow" attribute. |     If nofollow is True, the URLs in link text will get a rel="nofollow" | ||||||
|  |     attribute. | ||||||
|     """ |     """ | ||||||
|     trim_url = lambda x, limit=trim_url_limit: limit is not None and (x[:limit] + (len(x) >=limit and '...' or ''))  or x |     trim_url = lambda x, limit=trim_url_limit: limit is not None and (len(x) > limit and ('%s...' % x[:max(0, limit - 3)])) or x | ||||||
|     words = word_split_re.split(text) |     words = word_split_re.split(text) | ||||||
|     nofollow_attr = nofollow and ' rel="nofollow"' or '' |     nofollow_attr = nofollow and ' rel="nofollow"' or '' | ||||||
|     for i, word in enumerate(words): |     for i, word in enumerate(words): | ||||||
|   | |||||||
| @@ -1266,7 +1266,8 @@ Converts URLs in plain text into clickable links. | |||||||
| urlizetrunc | urlizetrunc | ||||||
| ~~~~~~~~~~~ | ~~~~~~~~~~~ | ||||||
|  |  | ||||||
| Converts URLs into clickable links, truncating URLs to the given character limit. | Converts URLs into clickable links, truncating URLs longer than the given | ||||||
|  | character limit. | ||||||
|  |  | ||||||
| **Argument:** Length to truncate URLs to | **Argument:** Length to truncate URLs to | ||||||
|  |  | ||||||
|   | |||||||
| @@ -121,7 +121,18 @@ u'\xcb' | |||||||
| '<a href="http://short.com/" rel="nofollow">http://short.com/</a>' | '<a href="http://short.com/" rel="nofollow">http://short.com/</a>' | ||||||
|  |  | ||||||
| >>> urlizetrunc('http://www.google.co.uk/search?hl=en&q=some+long+url&btnG=Search&meta=', 20) | >>> urlizetrunc('http://www.google.co.uk/search?hl=en&q=some+long+url&btnG=Search&meta=', 20) | ||||||
| '<a href="http://www.google.co.uk/search?hl=en&q=some+long+url&btnG=Search&meta=" rel="nofollow">http://www.google.co...</a>' | '<a href="http://www.google.co.uk/search?hl=en&q=some+long+url&btnG=Search&meta=" rel="nofollow">http://www.google...</a>' | ||||||
|  |  | ||||||
|  | # Check truncating of URIs which are the exact length | ||||||
|  | >>> uri = 'http://31characteruri.com/test/' | ||||||
|  | >>> len(uri) | ||||||
|  | 31 | ||||||
|  | >>> urlizetrunc(uri, 31) | ||||||
|  | '<a href="http://31characteruri.com/test/" rel="nofollow">http://31characteruri.com/test/</a>' | ||||||
|  | >>> urlizetrunc(uri, 30) | ||||||
|  | '<a href="http://31characteruri.com/test/" rel="nofollow">http://31characteruri.com/t...</a>' | ||||||
|  | >>> urlizetrunc(uri, 2) | ||||||
|  | '<a href="http://31characteruri.com/test/" rel="nofollow">...</a>' | ||||||
|  |  | ||||||
| >>> wordcount('') | >>> wordcount('') | ||||||
| 0 | 0 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user