137 lines
4.2 KiB
Python
137 lines
4.2 KiB
Python
# FIXME: this should all be confirmed against what a DTD says
|
|
# (probably in a test; this may not match the DTD exactly, but we
|
|
# should document just how it differs).
|
|
|
|
# Data taken from http://www.w3.org/TR/html401/index/elements.html
|
|
# and http://www.w3.org/community/webed/wiki/HTML/New_HTML5_Elements
|
|
# for html5_tags.
|
|
|
|
try:
|
|
frozenset
|
|
except NameError:
|
|
from sets import Set as frozenset
|
|
|
|
|
|
empty_tags = frozenset([
|
|
'area', 'base', 'basefont', 'br', 'col', 'frame', 'hr',
|
|
'img', 'input', 'isindex', 'link', 'meta', 'param'])
|
|
|
|
deprecated_tags = frozenset([
|
|
'applet', 'basefont', 'center', 'dir', 'font', 'isindex',
|
|
'menu', 's', 'strike', 'u'])
|
|
|
|
# archive actually takes a space-separated list of URIs
|
|
link_attrs = frozenset([
|
|
'action', 'archive', 'background', 'cite', 'classid',
|
|
'codebase', 'data', 'href', 'longdesc', 'profile', 'src',
|
|
'usemap',
|
|
# Not standard:
|
|
'dynsrc', 'lowsrc',
|
|
])
|
|
|
|
# Not in the HTML 4 spec:
|
|
# onerror, onresize
|
|
event_attrs = frozenset([
|
|
'onblur', 'onchange', 'onclick', 'ondblclick', 'onerror',
|
|
'onfocus', 'onkeydown', 'onkeypress', 'onkeyup', 'onload',
|
|
'onmousedown', 'onmousemove', 'onmouseout', 'onmouseover',
|
|
'onmouseup', 'onreset', 'onresize', 'onselect', 'onsubmit',
|
|
'onunload',
|
|
])
|
|
|
|
safe_attrs = frozenset([
|
|
'abbr', 'accept', 'accept-charset', 'accesskey', 'action', 'align',
|
|
'alt', 'axis', 'border', 'cellpadding', 'cellspacing', 'char', 'charoff',
|
|
'charset', 'checked', 'cite', 'class', 'clear', 'cols', 'colspan',
|
|
'color', 'compact', 'coords', 'datetime', 'dir', 'disabled', 'enctype',
|
|
'for', 'frame', 'headers', 'height', 'href', 'hreflang', 'hspace', 'id',
|
|
'ismap', 'label', 'lang', 'longdesc', 'maxlength', 'media', 'method',
|
|
'multiple', 'name', 'nohref', 'noshade', 'nowrap', 'prompt', 'readonly',
|
|
'rel', 'rev', 'rows', 'rowspan', 'rules', 'scope', 'selected', 'shape',
|
|
'size', 'span', 'src', 'start', 'summary', 'tabindex', 'target', 'title',
|
|
'type', 'usemap', 'valign', 'value', 'vspace', 'width'])
|
|
|
|
# From http://htmlhelp.com/reference/html40/olist.html
|
|
top_level_tags = frozenset([
|
|
'html', 'head', 'body', 'frameset',
|
|
])
|
|
|
|
head_tags = frozenset([
|
|
'base', 'isindex', 'link', 'meta', 'script', 'style', 'title',
|
|
])
|
|
|
|
general_block_tags = frozenset([
|
|
'address',
|
|
'blockquote',
|
|
'center',
|
|
'del',
|
|
'div',
|
|
'h1',
|
|
'h2',
|
|
'h3',
|
|
'h4',
|
|
'h5',
|
|
'h6',
|
|
'hr',
|
|
'ins',
|
|
'isindex',
|
|
'noscript',
|
|
'p',
|
|
'pre',
|
|
])
|
|
|
|
list_tags = frozenset([
|
|
'dir', 'dl', 'dt', 'dd', 'li', 'menu', 'ol', 'ul',
|
|
])
|
|
|
|
table_tags = frozenset([
|
|
'table', 'caption', 'colgroup', 'col',
|
|
'thead', 'tfoot', 'tbody', 'tr', 'td', 'th',
|
|
])
|
|
|
|
# just this one from
|
|
# http://www.georgehernandez.com/h/XComputers/HTML/2BlockLevel.htm
|
|
block_tags = general_block_tags | list_tags | table_tags | frozenset([
|
|
# Partial form tags
|
|
'fieldset', 'form', 'legend', 'optgroup', 'option',
|
|
])
|
|
|
|
form_tags = frozenset([
|
|
'form', 'button', 'fieldset', 'legend', 'input', 'label',
|
|
'select', 'optgroup', 'option', 'textarea',
|
|
])
|
|
|
|
special_inline_tags = frozenset([
|
|
'a', 'applet', 'basefont', 'bdo', 'br', 'embed', 'font', 'iframe',
|
|
'img', 'map', 'area', 'object', 'param', 'q', 'script',
|
|
'span', 'sub', 'sup',
|
|
])
|
|
|
|
phrase_tags = frozenset([
|
|
'abbr', 'acronym', 'cite', 'code', 'del', 'dfn', 'em',
|
|
'ins', 'kbd', 'samp', 'strong', 'var',
|
|
])
|
|
|
|
font_style_tags = frozenset([
|
|
'b', 'big', 'i', 's', 'small', 'strike', 'tt', 'u',
|
|
])
|
|
|
|
frame_tags = frozenset([
|
|
'frameset', 'frame', 'noframes',
|
|
])
|
|
|
|
html5_tags = frozenset([
|
|
'article', 'aside', 'audio', 'canvas', 'command', 'datalist',
|
|
'details', 'embed', 'figcaption', 'figure', 'footer', 'header',
|
|
'hgroup', 'keygen', 'mark', 'math', 'meter', 'nav', 'output',
|
|
'progress', 'rp', 'rt', 'ruby', 'section', 'source', 'summary',
|
|
'svg', 'time', 'track', 'video', 'wbr'
|
|
])
|
|
|
|
# These tags aren't standard
|
|
nonstandard_tags = frozenset(['blink', 'marquee'])
|
|
|
|
|
|
tags = (top_level_tags | head_tags | general_block_tags | list_tags
|
|
| table_tags | form_tags | special_inline_tags | phrase_tags
|
|
| font_style_tags | nonstandard_tags | html5_tags)
|