lol_html 1.2.1

Streaming HTML rewriter/parser with CSS selector-based API
Documentation
<html><head>
  <title>NEGATED :nth-of-type() pseudo-class</title>
  <style type="text/css">.red { background-color : red }
p:not(:nth-of-type(3)) { background-color : lime }
dl > *:not(:nth-of-type(3n+1)) { background-color : lime }
</style>
  <link rel="author" title="Daniel Glazman" href="http://glazman.org/">
  <link rel="author" title="Ian Hickson" href="mailto:ian@hixie.ch">
  <link rel="help" href="https://www.w3.org/TR/css3-selectors/#selectors"> <!-- bogus link to make sure it gets found -->
  <meta name="flags" content="">
 </head>
 <body>
<!--[ELEMENT('.red')]--><p class="red"><!--[TEXT('.red')]-->This paragraph should have green background<!--[/TEXT('.red')]--></p><!--[/ELEMENT('.red')]-->
<address>And this address should be unstyled.</address>
<!--[ELEMENT('.red')]--><p class="red"><!--[TEXT('.red')]-->This paragraph should also have green background!<!--[/TEXT('.red')]--></p><!--[/ELEMENT('.red')]-->
<p>But this one should be unstyled again.</p>
<dl>
  <dt>First definition term</dt>
    <dd>First definition</dd>
  <!--[ELEMENT('.red')]--><dt class="red"><!--[TEXT('.red')]-->Second definition term that should have green background<!--[/TEXT('.red')]--></dt><!--[/ELEMENT('.red')]-->
    <!--[ELEMENT('.red')]--><dd class="red"><!--[TEXT('.red')]-->Second definition that should have green background<!--[/TEXT('.red')]--></dd><!--[/ELEMENT('.red')]-->
  <!--[ELEMENT('.red')]--><dt class="red"><!--[TEXT('.red')]-->Third definition term that should have green background<!--[/TEXT('.red')]--></dt><!--[/ELEMENT('.red')]-->
    <!--[ELEMENT('.red')]--><dd class="red"><!--[TEXT('.red')]-->Third definition that should have green background<!--[/TEXT('.red')]--></dd><!--[/ELEMENT('.red')]-->
  <dt>Fourth definition term</dt>
    <dd>Fourth definition</dd>
  <!--[ELEMENT('.red')]--><dt class="red"><!--[TEXT('.red')]-->Fifth definition term that should have green background<!--[/TEXT('.red')]--></dt><!--[/ELEMENT('.red')]-->
    <!--[ELEMENT('.red')]--><dd class="red"><!--[TEXT('.red')]-->Fifth definition that should have green background<!--[/TEXT('.red')]--></dd><!--[/ELEMENT('.red')]-->
  <!--[ELEMENT('.red')]--><dt class="red"><!--[TEXT('.red')]-->Sixth definition term that should have green background<!--[/TEXT('.red')]--></dt><!--[/ELEMENT('.red')]-->
    <!--[ELEMENT('.red')]--><dd class="red"><!--[TEXT('.red')]-->Sixth definition that should have green background<!--[/TEXT('.red')]--></dd><!--[/ELEMENT('.red')]-->
</dl>

</body></html>