- when TYPE_START_TAG
- switch t.name
- when 'html'
- parse_error()
- return if template_tag_is_open()
- root_attrs = open_els[open_els.length - 1].attrs
- for k, v of t.attrs
- root_attrs[k] = v unless root_attrs[k]?
- when 'base', 'basefont', 'bgsound', 'link', 'meta', 'noframes', 'script', 'style', 'template', 'title'
- # FIXME also do this for </template> (end tag)
- return ins_mode_in_head t
- when 'body'
- parse_error()
- # TODO
- when 'frameset'
- parse_error()
- # TODO
- when 'address', 'article', 'aside', 'blockquote', 'center', 'details', 'dialog', 'dir', 'div', 'dl', 'fieldset', 'figcaption', 'figure', 'footer', 'header', 'hgroup', 'main', 'nav', 'ol', 'p', 'section', 'summary', 'ul'
- close_p_if_in_button_scope()
- insert_html_element t
- when 'h1', 'h2', 'h3', 'h4', 'h5', 'h6'
- close_p_if_in_button_scope()
- if open_els[0].name in ['h1', 'h2', 'h3', 'h4', 'h5', 'h6']
- parse_error()
- open_els.shift()
- insert_html_element t
- # TODO lots more to implement here
- when 'a'
- # If the list of active formatting elements
- # contains an a element between the end of the list and
- # the last marker on the list (or the start of the list
- # if there is no marker on the list), then this is a
- # parse error; run the adoption agency algorithm for
- # the tag name "a", then remove that element from the
- # list of active formatting elements and the stack of
- # open elements if the adoption agency algorithm didn't
- # already remove it (it might not have if the element
- # is not in table scope).
- found = false
- for el in afe
- if el.type is TYPE_AFE_MARKER
- break
- if el.name is 'a'
- found = el
- if found?
- parse_error()
- adoption_agency 'a'
- for el, i in afe
- if el is found
- afe.splice i, 1
- for el, i in open_els
- if el is found
- open_els.splice i, 1
- reconstruct_active_formatting_elements()
- el = insert_html_element t
- afe_push el
- when 'b', 'big', 'code', 'em', 'font', 'i', 's', 'small', 'strike', 'strong', 'tt', 'u'
- reconstruct_active_formatting_elements()
- el = insert_html_element t
- afe_push el
- when 'table'
- # fixfull quirksmode thing
- close_p_if_in_button_scope()
- insert_html_element t
- insertion_mode = ins_mode_in_table
- # TODO lots more to implement here
- else # any other start tag
- reconstruct_active_formatting_elements()
- insert_html_element t
- when TYPE_EOF
- ok_tags = {
- dd: true, dt: true, li: true, p: true, tbody: true, td: true,
- tfoot: true, th: true, thead: true, tr: true, body: true, html: true,
- }
- for t in open_els
- unless ok_tags[t.name]?
- parse_error()
- break
- # TODO stack of template insertion modes thing
- stop_parsing()
- when TYPE_END_TAG
- switch t.name
- when 'body'
- unless is_in_scope 'body'
- parse_error()
- return
- # TODO implement parse error and move to tree_after_body
- when 'html'
- unless is_in_scope 'body' # weird, but it's what the spec says
- parse_error()
- return
- # TODO implement parse error and move to tree_after_body, reprocess
- when 'address', 'article', 'aside', 'blockquote', 'button', 'center', 'details', 'dialog', 'dir', 'div', 'dl', 'fieldset', 'figcaption', 'figure', 'footer', 'header', 'hgroup', 'listing', 'main', 'nav', 'ol', 'pre', 'section', 'summary', 'ul'
- unless is_in_scope t.name, NS_HTML
- parse_error()
- return
- generate_implied_end_tags()
- unless open_els[0].name is t.name and open_els[0].namespace is NS_HTML
- parse_error()
- loop
- el = open_els.shift()
- if el.name is t.name and el.namespace is NS_HTML
- return
- # TODO lots more close tags to implement here
- when 'p'
- unless is_in_button_scope 'p'
- parse_error()
- insert_html_element new_open_tag 'p'
- close_p_element()
- # TODO lots more close tags to implement here
- when 'a', 'b', 'big', 'code', 'em', 'font', 'i', 'nobr', 's', 'small', 'strike', 'strong', 'tt', 'u'
- adoption_agency t.name
- # TODO lots more close tags to implement here
- else
- in_body_any_other_end_tag t.name
+ open_els.shift()
+ insert_html_element t
+ return
+ # FIXME CONTINUE
+ if t.type is TYPE_START_TAG and t.name is 'a'
+ # If the list of active formatting elements contains an a element
+ # between the end of the list and the last marker on the list (or
+ # the start of the list if there is no marker on the list), then
+ # this is a parse error; run the adoption agency algorithm for the
+ # tag name "a", then remove that element from the list of active
+ # formatting elements and the stack of open elements if the
+ # adoption agency algorithm didn't already remove it (it might not
+ # have if the element is not in table scope).
+ found = false
+ for el in afe
+ if el.type is TYPE_AFE_MARKER
+ break
+ if el.name is 'a'
+ found = el
+ if found?
+ parse_error()
+ adoption_agency 'a'
+ for el, i in afe
+ if el is found
+ afe.splice i, 1
+ for el, i in open_els
+ if el is found
+ open_els.splice i, 1
+ reconstruct_active_formatting_elements()
+ el = insert_html_element t
+ afe_push el
+ return
+ if t.type is TYPE_START_TAG and (t.name is 'b' or t.name is 'big' or t.name is 'code' or t.name is 'em' or t.name is 'font' or t.name is 'i' or t.name is 's' or t.name is 'small' or t.name is 'strike' or t.name is 'strong' or t.name is 'tt' or t.name is 'u')
+ reconstruct_active_formatting_elements()
+ el = insert_html_element t
+ afe_push el
+ return
+ if t.type is TYPE_START_TAG and t.name is 'table'
+ # fixfull quirksmode thing
+ close_p_if_in_button_scope()
+ insert_html_element t
+ insertion_mode = ins_mode_in_table
+ return
+ # FIXME CONTINUE
+ if t.type is TYPE_EOF
+ ok_tags = {
+ dd: true, dt: true, li: true, p: true, tbody: true, td: true,
+ tfoot: true, th: true, thead: true, tr: true, body: true, html: true,
+ }
+ for t in open_els
+ unless ok_tags[t.name]?
+ parse_error()
+ break
+ # FIXME stack of template insertion modes thing
+ stop_parsing()
+ return
+ # FIXME CONTINUE some of these next ones are out of order I think
+ if t.type is TYPE_END_TAG and t.name is 'body'
+ unless is_in_scope 'body'
+ parse_error()
+ return
+ # fixme implement parse error and move to tree_after_body
+ return
+ if t.type is TYPE_END_TAG and t.name is 'html'
+ unless is_in_scope 'body' # weird, but it's what the spec says
+ parse_error()
+ return
+ # TODO implement parse error and move to tree_after_body, reprocess
+ return
+ if t.type is TYPE_END_TAG and (t.name is 'address' or t.name is 'article' or t.name is 'aside' or t.name is 'blockquote' or t.name is 'button' or t.name is 'center' or t.name is 'details' or t.name is 'dialog' or t.name is 'dir' or t.name is 'div' or t.name is 'dl' or t.name is 'fieldset' or t.name is 'figcaption' or t.name is 'figure' or t.name is 'footer' or t.name is 'header' or t.name is 'hgroup' or t.name is 'listing' or t.name is 'main' or t.name is 'nav' or t.name is 'ol' or t.name is 'pre' or t.name is 'section' or t.name is 'summary' or t.name is 'ul')
+ unless is_in_scope t.name, NS_HTML
+ parse_error()
+ return
+ generate_implied_end_tags()
+ unless open_els[0].name is t.name and open_els[0].namespace is NS_HTML
+ parse_error()
+ loop
+ el = open_els.shift()
+ if el.name is t.name and el.namespace is NS_HTML
+ return
+ return
+ if t.type is TYPE_END_TAG and t.name is 'p'
+ unless is_in_button_scope 'p'
+ parse_error()
+ insert_html_element new_open_tag 'p'
+ close_p_element()
+ return
+ if t.type is TYPE_END_TAG and (t.name is 'a' or t.name is 'b' or t.name is 'big' or t.name is 'code' or t.name is 'em' or t.name is 'font' or t.name is 'i' or t.name is 'nobr' or t.name is 's' or t.name is 'small' or t.name is 'strike' or t.name is 'strong' or t.name is 'tt' or t.name is 'u')
+ adoption_agency t.name
+ return
+ if t.type is TYPE_START_TAG # any other start tag
+ reconstruct_active_formatting_elements()
+ insert_html_element t
+ return
+ if t.type is TYPE_END_TAG # any other end tag
+ in_body_any_other_end_tag t.name