Commit 9bb718a2 authored by Guido van Rossum's avatar Guido van Rossum

More special cases when generating backwards compatible "html":

- Only minimize empty elements when the content model is empty,
  keeping an explicit list of which elements have an empty content
  model (e.g. <img>, etc.).  This checks whether the tagname is in an
  explicit list of such elements; the check is case insensitive.

- Minimize certain attributes that are considered Boolean by HTML,
  e.g. ismap.  Again, this does a case-insensitive check whether the
  attribute name is in a list of known Boolean attributes.

Note: this should really be refactored, making HTML support a subclass
rather than a keyword argument.  Later...
parent 680fc80a
...@@ -93,6 +93,23 @@ import cgi ...@@ -93,6 +93,23 @@ import cgi
from TALCompiler import TALCompiler from TALCompiler import TALCompiler
BOOLEAN_HTML_ATTRS = [
# List of Boolean attributes in HTML that should be rendered in
# minimized form (e.g. <img ismap> rather than <img ismap="">)
# From http://www.w3.org/TR/xhtml1/#guidelines (C.10)
"compact", "nowrap", "ismap", "declare", "noshade", "checked",
"disabled", "readonly", "multiple", "selected", "noresize",
"defer"
]
EMPTY_HTML_TAGS = [
# List of HTML tags with an empty content model; these are
# rendered in minimized form, e.g. <img />.
# From http://www.w3.org/TR/xhtml1/#dtds
"base", "meta", "link", "hr", "br", "param", "img", "area",
"input", "col", "basefont", "isindex", "frame",
]
class TALInterpreter: class TALInterpreter:
def __init__(self, program, macros, engine, stream=None, def __init__(self, program, macros, engine, stream=None,
...@@ -146,6 +163,10 @@ class TALInterpreter: ...@@ -146,6 +163,10 @@ class TALInterpreter:
self.level = self.level - 1 self.level = self.level - 1
def do_startEndTag(self, name, attrList): def do_startEndTag(self, name, attrList):
if self.html and string.lower(name) not in EMPTY_HTML_TAGS:
self.do_startTag(name, attrList)
self.do_endTag(name)
else:
self.do_startTag(name, attrList, self.endsep) self.do_startTag(name, attrList, self.endsep)
def do_startTag(self, name, attrList, end=">"): def do_startTag(self, name, attrList, end=">"):
...@@ -164,14 +185,17 @@ class TALInterpreter: ...@@ -164,14 +185,17 @@ class TALInterpreter:
name[-13:] == ":define-macro" and self.metal): name[-13:] == ":define-macro" and self.metal):
name = name[:-13] + ":use-macro" name = name[:-13] + ":use-macro"
value = self.currentMacro value = self.currentMacro
if (self.html and not value and
string.lower(name) in BOOLEAN_HTML_ATTRS):
s = name
else:
s = "%s=%s" % (name, quote(value)) s = "%s=%s" % (name, quote(value))
if (self.wrap and if (self.wrap and
self.col >= align and self.col >= align and
self.col + 1 + len(s) > self.wrap): self.col + 1 + len(s) > self.wrap):
self.stream_write("\n" + " "*align) self.stream_write("\n" + " "*align + s)
else: else:
self.stream_write(" ") self.stream_write(" " + s)
self.stream_write(s)
self.stream_write(end) self.stream_write(end)
def do_endTag(self, name): def do_endTag(self, name):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment