Fixed #10094 -- Fixed the `include` and `extends` template tags to work with filenames with spaces, patch from mcroydon.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@10211 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
9ac3905f01
commit
86c5142461
|
@ -158,7 +158,7 @@ def do_extends(parser, token):
|
||||||
name of the parent template to extend (if it evaluates to a string) or as
|
name of the parent template to extend (if it evaluates to a string) or as
|
||||||
the parent tempate itelf (if it evaluates to a Template object).
|
the parent tempate itelf (if it evaluates to a Template object).
|
||||||
"""
|
"""
|
||||||
bits = token.contents.split()
|
bits = token.split_contents()
|
||||||
if len(bits) != 2:
|
if len(bits) != 2:
|
||||||
raise TemplateSyntaxError, "'%s' takes one argument" % bits[0]
|
raise TemplateSyntaxError, "'%s' takes one argument" % bits[0]
|
||||||
parent_name, parent_name_expr = None, None
|
parent_name, parent_name_expr = None, None
|
||||||
|
@ -179,7 +179,7 @@ def do_include(parser, token):
|
||||||
|
|
||||||
{% include "foo/some_include" %}
|
{% include "foo/some_include" %}
|
||||||
"""
|
"""
|
||||||
bits = token.contents.split()
|
bits = token.split_contents()
|
||||||
if len(bits) != 2:
|
if len(bits) != 2:
|
||||||
raise TemplateSyntaxError, "%r tag takes one argument: the name of the template to be included" % bits[0]
|
raise TemplateSyntaxError, "%r tag takes one argument: the name of the template to be included" % bits[0]
|
||||||
path = bits[1]
|
path = bits[1]
|
||||||
|
|
|
@ -661,6 +661,8 @@ class Templates(unittest.TestCase):
|
||||||
'include02': ('{% include "basic-syntax02" %}', {'headline': 'Included'}, "Included"),
|
'include02': ('{% include "basic-syntax02" %}', {'headline': 'Included'}, "Included"),
|
||||||
'include03': ('{% include template_name %}', {'template_name': 'basic-syntax02', 'headline': 'Included'}, "Included"),
|
'include03': ('{% include template_name %}', {'template_name': 'basic-syntax02', 'headline': 'Included'}, "Included"),
|
||||||
'include04': ('a{% include "nonexistent" %}b', {}, "ab"),
|
'include04': ('a{% include "nonexistent" %}b', {}, "ab"),
|
||||||
|
'include 05': ('template with a space', {}, 'template with a space'),
|
||||||
|
'include06': ('{% include "include 05"%}', {}, 'template with a space'),
|
||||||
|
|
||||||
### NAMED ENDBLOCKS #######################################################
|
### NAMED ENDBLOCKS #######################################################
|
||||||
|
|
||||||
|
@ -760,6 +762,12 @@ class Templates(unittest.TestCase):
|
||||||
# Inheritance from a template that doesn't have any blocks
|
# Inheritance from a template that doesn't have any blocks
|
||||||
'inheritance27': ("{% extends 'inheritance26' %}", {}, 'no tags'),
|
'inheritance27': ("{% extends 'inheritance26' %}", {}, 'no tags'),
|
||||||
|
|
||||||
|
# Set up a base template with a space in it.
|
||||||
|
'inheritance 28': ("{% block first %}!{% endblock %}", {}, '!'),
|
||||||
|
|
||||||
|
# Inheritance from a template with a space in its name should work.
|
||||||
|
'inheritance29': ("{% extends 'inheritance 28' %}", {}, '!'),
|
||||||
|
|
||||||
### I18N ##################################################################
|
### I18N ##################################################################
|
||||||
|
|
||||||
# {% spaceless %} tag
|
# {% spaceless %} tag
|
||||||
|
|
Loading…
Reference in New Issue