diff --git a/django/template/defaultfilters.py b/django/template/defaultfilters.py
index b68cc03e6d..13de9d5334 100644
--- a/django/template/defaultfilters.py
+++ b/django/template/defaultfilters.py
@@ -19,6 +19,7 @@ from django.utils.text import Truncator, wrap, phone2numeric
from django.utils.safestring import mark_safe, SafeData, mark_for_escaping
from django.utils.timesince import timesince, timeuntil
from django.utils.translation import ugettext, ungettext
+from django.utils.text import normalize_newlines
register = Library()
@@ -421,13 +422,16 @@ def linebreaks_filter(value, autoescape=None):
return mark_safe(linebreaks(value, autoescape))
linebreaks_filter.is_safe = True
linebreaks_filter.needs_autoescape = True
+linebreaks = stringfilter(linebreaks)
def linebreaksbr(value, autoescape=None):
"""
Converts all newlines in a piece of plain text to HTML line breaks
(``
``).
"""
- if autoescape and not isinstance(value, SafeData):
+ autoescape = autoescape and not isinstance(value, SafeData)
+ value = normalize_newlines(value)
+ if autoescape:
value = escape(value)
return mark_safe(value.replace('\n', '
'))
linebreaksbr.is_safe = True
diff --git a/django/utils/html.py b/django/utils/html.py
index 7fda015840..2687eb5232 100644
--- a/django/utils/html.py
+++ b/django/utils/html.py
@@ -7,6 +7,7 @@ from django.utils.safestring import SafeData, mark_safe
from django.utils.encoding import force_unicode
from django.utils.functional import allow_lazy
from django.utils.http import urlquote
+from django.utils.text import normalize_newlines
# Configuration for urlize() function.
LEADING_PUNCTUATION = ['(', '<', '<']
@@ -70,7 +71,7 @@ def conditional_escape(html):
def linebreaks(value, autoescape=False):
"""Converts newlines into
and
s."""
- value = re.sub(r'\r\n|\r|\n', '\n', force_unicode(value)) # normalize newlines
+ value = normalize_newlines(value)
paras = re.split('\n{2,}', value)
if autoescape:
paras = [u'
%s
' % escape(p).replace('\n', 'line 1
') self.assertEqual(linebreaks(u'line 1\nline 2'), u'line 1
line 2
line 1
line 2
line 1
line 2