| 10 |
<div class="header"> |
<div class="header"> |
| 11 |
<h1>Selectors Serialization Format for Testing (<abbr>SSFT</abbr>) |
<h1>Selectors Serialization Format for Testing (<abbr>SSFT</abbr>) |
| 12 |
Specification</h1> |
Specification</h1> |
| 13 |
<h2>Working Draft <time datetime=2007-10-15>15 October 2007</time></h2> |
<h2>Working Draft <time datetime=2007-10-22>22 October 2007</time></h2> |
| 14 |
|
|
| 15 |
<dl class="versions-uri"> |
<dl class="versions-uri"> |
| 16 |
<dt>This Version</dt> |
<dt>This Version</dt> |
| 63 |
at the time of its publication. Other documents |
at the time of its publication. Other documents |
| 64 |
might supersede this document.</em></p> |
might supersede this document.</em></p> |
| 65 |
|
|
| 66 |
<p>This document is a working draft, produced as part |
<p>This document is a working draft, produced as part of the |
| 67 |
|
<a href="http://suika.fam.cx/www/markup/html/whatpm/readme">Whatpm</a> |
| 68 |
|
subproject |
| 69 |
of the <a href="http://suika.fam.cx/www/manakai-core/doc/web/">manakai</a> |
of the <a href="http://suika.fam.cx/www/manakai-core/doc/web/">manakai</a> |
| 70 |
project. It might be updated, replaced, or obsoleted by |
project. It might be updated, replaced, or obsoleted by |
| 71 |
other documents at any time. It is inappropriate to |
other documents at any time. It is inappropriate to |
| 118 |
<div class="section" id="terminology"> |
<div class="section" id="terminology"> |
| 119 |
<h2>Terminology</h2> |
<h2>Terminology</h2> |
| 120 |
|
|
| 121 |
<p>The key words <q><em class="rfc2119">MUST</em></q>, |
<p>The key words <q><dfn id=must><em class="rfc2119">MUST</em></dfn></q>, |
| 122 |
<q><em class="rfc2119">MUST NOT</em></q>, |
<q><dfn id=must-not><em class="rfc2119">MUST NOT</em></dfn></q>, |
| 123 |
<q><em class="rfc2119">SHOULD</em></q>, |
<q><dfn id=should><em class="rfc2119">SHOULD</em></dfn></q>, |
| 124 |
<q><em class="rfc2119">SHOULD NOT</em></q>, and |
<q><dfn id=should-not><em class="rfc2119">SHOULD NOT</em></dfn></q>, and |
| 125 |
<q><em class=rfc2119>MAY</em></q> in this |
<q><dfn id=may><em class=rfc2119>MAY</em></dfn></q> in this |
| 126 |
document are to be interpreted as described in |
document are to be interpreted as described in |
| 127 |
<a href="urn:ietf:rfc:2119"><abbr title="Request for Comments">RFC</abbr> |
<a href="urn:ietf:rfc:2119"><abbr title="Request for Comments">RFC</abbr> |
| 128 |
2119</a> |
2119</a> |
| 175 |
<dl class=switch> |
<dl class=switch> |
| 176 |
<dt>If it is a sequence of simle selector |
<dt>If it is a sequence of simle selector |
| 177 |
(<dfn id=var-sss><var>sss</var></dfn>)</dt> |
(<dfn id=var-sss><var>sss</var></dfn>)</dt> |
| 178 |
<dd class=ed>@@</dd> |
<dd> |
| 179 |
|
<ol> |
| 180 |
|
<li class=ed><a href="#algorithm-serialize-a-simple-selector">Serialize |
| 181 |
|
each simple selector</a> in <var>sss</var>.</li> |
| 182 |
|
<li class=ed>sort</li> |
| 183 |
|
<li>Append a <a href="#newline">newline</a> to <var>result</var>.</li> |
| 184 |
|
</ol> |
| 185 |
|
</dd> |
| 186 |
<dt>If it is a combinator (<dfn id=var-c><var>c</var></dfn>)</dt> |
<dt>If it is a combinator (<dfn id=var-c><var>c</var></dfn>)</dt> |
| 187 |
<dd> |
<dd> |
| 188 |
<ol> |
<ol> |
| 252 |
</dl> |
</dl> |
| 253 |
</li> |
</li> |
| 254 |
<li>If <var>ss</var> is a type selector, append the |
<li>If <var>ss</var> is a type selector, append the |
| 255 |
<span class=ed>@@ normalized</span> local name to <var>result</var>.</li> |
<a href="#algorithm-normalize-an-ident" title="normalize an IDENT">normalized</a> |
| 256 |
|
local name to <var>result</var>.</li> |
| 257 |
<li>If <var>ss</var> is a universal selector, append |
<li>If <var>ss</var> is a universal selector, append |
| 258 |
a <code class=char>U+002A</code> <code class=charname>ASTERISK</code> |
a <code class=char>U+002A</code> <code class=charname>ASTERISK</code> |
| 259 |
(<code class=char>*</code>) character to <var>result</var>.</li> |
(<code class=char>*</code>) character to <var>result</var>.</li> |
| 260 |
</ol> |
</ol> |
| 261 |
</dd> |
</dd> |
| 262 |
<dt>If <var>ss</var> is an attribute selector</dt> |
<dt>If <var>ss</var> is an attribute selector</dt> |
| 263 |
<dd class=ed>@@</dd> |
<dd> |
| 264 |
|
<ol> |
| 265 |
|
<li>Append a <code class=char>U+005B</code> <code class=charname>LEFT |
| 266 |
|
SQUARE BRACKET</code> (<code class=char>[</code>) to |
| 267 |
|
<var>result</var>.</li> |
| 268 |
|
<li> |
| 269 |
|
Append a namespace prefix as following: |
| 270 |
|
<dl> |
| 271 |
|
<dt>If a namespace URI is specified</dt> |
| 272 |
|
<dd class=ed>@@</dd> |
| 273 |
|
<dd class=ed>@@ Current reference implementation is wrong, |
| 274 |
|
since its result of sorting depends on namespace prefix.</dd> |
| 275 |
|
<dt>If the null namespace is specified</dt> |
| 276 |
|
<dd>Append a <code class=char>U+007C</code> |
| 277 |
|
<code class=charname>VERTICAL BAR</code> character to |
| 278 |
|
<var>result</var>.</dd> |
| 279 |
|
<dt>If no namespace is specified</dt> |
| 280 |
|
<dd>Append a <code class=char>U+002A</code> |
| 281 |
|
<code class=charname>ASTERISK</code> (<code class=char>*</code>) |
| 282 |
|
character, followed by a <code class=char>U+007C</code> |
| 283 |
|
<code class=charname>VERTICAL BAR</code> (<code class=char>|</code>) |
| 284 |
|
character, to <var>result</var>.</dd> |
| 285 |
|
</dl> |
| 286 |
|
</li> |
| 287 |
|
<li>Append the |
| 288 |
|
<a href="#algorithm-normalize-an-ident" title="normalize an IDENT">normalized</a> |
| 289 |
|
local name to <var>result</var>.</li> |
| 290 |
|
<li>If a value is specified in <var>ss</var>: |
| 291 |
|
<ol> |
| 292 |
|
<li>Depending on the way to match, append <code>=</code>, |
| 293 |
|
<code>~=</code>, <code>|=</code>, <code>^=</code>, |
| 294 |
|
<code>$=</code>, or <code>*=</code> to <var>result</var>.</li> |
| 295 |
|
<li>Append the |
| 296 |
|
<a href="#algorithm-normalize-a-string" title="normalize a string">normalized</a> |
| 297 |
|
value to <var>result</var>.</li> |
| 298 |
|
</ol> |
| 299 |
|
</li> |
| 300 |
|
<li>Append a <code class=char>U+005D</code> <code class=charname>RIGHT |
| 301 |
|
SQUARE BRACKET</code> (<code class=char>]</code>) to |
| 302 |
|
<var>result</var>.</li> |
| 303 |
|
</ol> |
| 304 |
|
</dd> |
| 305 |
<dt>If <var>ss</var> is a class selector</dt> |
<dt>If <var>ss</var> is a class selector</dt> |
| 306 |
<dd>Append a <code class=char>U+002E</code> <code class=charname>FULL |
<dd>Append a <code class=char>U+002E</code> <code class=charname>FULL |
| 307 |
STOP</code> (<code class=char>.</code>) character, followed |
STOP</code> (<code class=char>.</code>) character, followed |
| 308 |
by <span class=ed>@@ normalized</span> class name, |
by <a href="#algorithm-normalize-an-ident" title="normalize an IDENT">normalized</a> |
| 309 |
<var>result</var>.</dd> |
class name, <var>result</var>.</dd> |
| 310 |
<dt>If <var>ss</var> is an <abbr>ID</abbr> selector</dt> |
<dt>If <var>ss</var> is an <abbr>ID</abbr> selector</dt> |
| 311 |
<dd>Append a <code class=char>U+0023</code> <code class=charname>NUMBER |
<dd>Append a <code class=char>U+0023</code> <code class=charname>NUMBER |
| 312 |
SIGN</code> (<code class=char>#</code>) character, followed |
SIGN</code> (<code class=char>#</code>) character, followed |
| 313 |
by <span class=ed>@@ normalized</span> <abbr>ID</abbr>, |
by <a href="#algorithm-normalize-an-ident" title="normalize an IDENT">normalized</a> |
| 314 |
to <var>result</var>.</dd> |
<abbr>ID</abbr>, to <var>result</var>.</dd> |
| 315 |
<dt>If <var>ss</var> is a pseudo$B!>(Bclass selector</dt> |
<dt>If <var>ss</var> is a pseudo$B!>(Bclass selector</dt> |
| 316 |
<dd> |
<dd> |
| 317 |
<ol> |
<ol> |
| 318 |
<li>Append a <code class=char>U+003A</code> |
<li>Append a <code class=char>U+003A</code> |
| 319 |
<code class=charname>COLON</code> (<code class=char>:</code>) character |
<code class=charname>COLON</code> (<code class=char>:</code>) character |
| 320 |
to <var>result</var>.</li> |
to <var>result</var>.</li> |
| 321 |
<li>Append the <span class=ed>@@ normalized</span> name of the |
<li>Append the |
| 322 |
pseudo$B!>(Bclass to <var>result</var>.</li> |
<a href="#algorithm-normalize-an-ident" title="normalize an IDENT">normalized</a> |
| 323 |
|
name of the pseudo$B!>(Bclass to <var>result</var>.</li> |
| 324 |
<li>Append any arguments as following: |
<li>Append any arguments as following: |
| 325 |
<dl class=switch> |
<dl class=switch> |
| 326 |
<dt>If the name of the pseudo$B!>(Bclass is <code>lang</code></dt> |
<dt>If the name of the pseudo$B!>(Bclass is <code>lang</code></dt> |
| 329 |
<li>Append a <code class=char>U+0028</code> <code class=charname>LEFT |
<li>Append a <code class=char>U+0028</code> <code class=charname>LEFT |
| 330 |
PARENTHESIS</code> (<code class=char>(</code>) character |
PARENTHESIS</code> (<code class=char>(</code>) character |
| 331 |
to <var>result</var>.</li> |
to <var>result</var>.</li> |
| 332 |
<li>Append <span class=ed>@@ normalized</span> |
<li>Append the |
| 333 |
|
<a href="#algorithm-normalize-an-ident" title="normalize an IDENT">normalized</a> |
| 334 |
language tag (the argument) to <var>result</var>.</li> |
language tag (the argument) to <var>result</var>.</li> |
| 335 |
<li>Append a <code class=char>U+0029</code> |
<li>Append a <code class=char>U+0029</code> |
| 336 |
<code class=charname>RIGHT PARENTHESIS</code> |
<code class=charname>RIGHT PARENTHESIS</code> |
| 345 |
<li>Append a <code class=char>U+0028</code> <code class=charname>LEFT |
<li>Append a <code class=char>U+0028</code> <code class=charname>LEFT |
| 346 |
PARENTHESIS</code> (<code class=char>(</code>) character |
PARENTHESIS</code> (<code class=char>(</code>) character |
| 347 |
to <var>result</var>.</li> |
to <var>result</var>.</li> |
| 348 |
<li>Append <span class=ed>@@ normalized</span> |
<li>Append the |
| 349 |
|
<a href="#algorithm-normalize-a-string" title="normalize a string">normalized</a> |
| 350 |
string (the argument) to <var>result</var>.</li> |
string (the argument) to <var>result</var>.</li> |
| 351 |
<li>Append a <code class=char>U+0029</code> |
<li>Append a <code class=char>U+0029</code> |
| 352 |
<code class=charname>RIGHT PARENTHESIS</code> |
<code class=charname>RIGHT PARENTHESIS</code> |
| 438 |
<li>Append two <code class=char>U+003A</code> |
<li>Append two <code class=char>U+003A</code> |
| 439 |
<code class=charname>COLON</code> characters (<code>::</code>) |
<code class=charname>COLON</code> characters (<code>::</code>) |
| 440 |
to <var>result</var>.</li> |
to <var>result</var>.</li> |
| 441 |
<li>Append the <span class=ed>@@ normalized</span> name of the |
<li>Append the |
| 442 |
pseudo$B!>(Belement to <var>result</var>.</li> |
<a href="#algorithm-normalize-an-ident" title="normalize an IDENT">normalized</a> |
| 443 |
|
name of the pseudo$B!>(Belement to <var>result</var>.</li> |
| 444 |
<!-- For future version: append "(", arguments, ")", if any. --> |
<!-- For future version: append "(", arguments, ")", if any. --> |
| 445 |
</ol> |
</ol> |
| 446 |
</dd> |
</dd> |
| 447 |
</dl> |
</dl> |
| 448 |
|
|
| 449 |
|
<p>To <dfn id=algorithm-normalize-an-ident title="normalize an IDENT">normalize |
| 450 |
|
an <code>IDENT</code> (<dfn id=var-n><var>n</var></dfn>)</dfn>:</p> |
| 451 |
|
<ol> |
| 452 |
|
<li>Replace the escape sequences (<code>\</code> and following |
| 453 |
|
characters) in <var>n</var> by characters represented by them |
| 454 |
|
respectively.</li> |
| 455 |
|
<li>If there is any character that is <em>not</em> one of |
| 456 |
|
<code class=char>U+002D</code> <code class=charname>HYPHEN-MINUS</code> |
| 457 |
|
(<code class=char>-</code>), <code class=char>U+0030</code> |
| 458 |
|
<code class=charname>DIGIT ZERO</code> |
| 459 |
|
(<code class=char>0</code>) to <code class=char>U+0039</code> |
| 460 |
|
<code class=charname>DIGIT NINE</code> (<code class=char>9</code>), |
| 461 |
|
<code class=char>U+0041</code> <code class=charname>LATIN CAPITAL LETTER |
| 462 |
|
A</code> (<code class=char>A</code>) to <code class=char>U+005A</code> |
| 463 |
|
<code class=charname>LATIN CAPITAL LETTER Z</code> (<code class=char>Z</code>), |
| 464 |
|
<code class=char>U+005F</code> <code class=charname>LOW LINE</code> |
| 465 |
|
(<code class=char>_</code>), <code class=char>U+0061</code> |
| 466 |
|
<code class=charname>LATIN SMALL LETTER A</code> |
| 467 |
|
(<code class=char>a</code>) to <code class=char>U+006A</code> |
| 468 |
|
<code class=charname>LATIN SMALL LETTER Z</code> (<code class=char>z</code>), |
| 469 |
|
<code class=char>U+0080</code> to <code class=char>U+D7FF</code>, or |
| 470 |
|
<code class=char>U+E000</code> to <code class=char>U+10FFFF</code> in |
| 471 |
|
<var>n</var>, then replace it by string <code>\<var>HHHHHH</var></code>, where |
| 472 |
|
<dfn id=var-HHHHHH><var>HHHHHH</var></dfn> is the upper$B!>(Bcase zero$B!>(Bpadded |
| 473 |
|
hexadecimal representation of the character. If the character |
| 474 |
|
is outside the range of <code>[<code class=char>U+0000</code>, |
| 475 |
|
<code class=char>U+10FFFF</code>]</code>, <var>HHHHHH</var> |
| 476 |
|
<em class=rfc2119>MUST</em> be <code>FFFFFF</code>.</li> |
| 477 |
|
<li>If the first character in <var>n</var> is one of |
| 478 |
|
<code class=char>U+0030</code> <code class=charname>DIGIT ZERO</code> |
| 479 |
|
(<code class=char>0</code>) to <code class=char>U+0039</code> |
| 480 |
|
<code class=charname>DIGIT NINE</code> (<code class=char>9</code>), |
| 481 |
|
then prepend a string <code>\00003</code> at the beginning of |
| 482 |
|
<var>n</var>.</li> |
| 483 |
|
<li>If the first character in <var>n</var> is <code class=char>U+002D</code> |
| 484 |
|
<code class=charname>HYPHEN-MINUS</code> (<code class=char>-</code>) and |
| 485 |
|
the second character, if any, is <em>not</em> one of |
| 486 |
|
<code class=char>U+0041</code> <code class=charname>LATIN CAPITAL LETTER |
| 487 |
|
A</code> (<code class=char>A</code>) to <code class=char>U+005A</code> |
| 488 |
|
<code class=charname>LATIN CAPITAL LETTER Z</code> (<code class=char>Z</code>), |
| 489 |
|
<code class=char>U+005F</code> <code class=charname>LOW LINE</code> |
| 490 |
|
(<code class=char>_</code>), <code class=char>U+0061</code> |
| 491 |
|
<code class=charname>LATIN SMALL LETTER A</code> |
| 492 |
|
(<code class=char>a</code>) to <code class=char>U+006A</code> |
| 493 |
|
<code class=charname>LATIN SMALL LETTER Z</code> (<code class=char>z</code>), |
| 494 |
|
<code>U+0080</code> to <code>U+D7FF</code>, or |
| 495 |
|
<code>U+E000</code> to <code>U+10FFFF</code>, or |
| 496 |
|
<var>n</var> is equal to <code class=char>U+002D</code> |
| 497 |
|
<code class=charname>HYPHEN-MINUS</code> (<code class=char>-</code>), then |
| 498 |
|
replace the <code class=char>U+002D</code> |
| 499 |
|
<code class=charname>HYPHEN-MINUS</code> (<code class=char>-</code>) |
| 500 |
|
character by string <code>\00002D</code>.</li> |
| 501 |
|
<li>Then, <var>n</var> is the result of the algorithm.</li> |
| 502 |
|
</ol> |
| 503 |
|
|
| 504 |
|
<p>To <dfn id=algorithm-normalize-a-string title="normalize a STRING">normalize |
| 505 |
|
a <code>STRING</code> (<dfn id=var-s><var>s</var></dfn>)</dfn>:</p> |
| 506 |
|
<ol> |
| 507 |
|
<li>Replace the escape sequences (<code>\</code> and following |
| 508 |
|
characters) in <var>s</var> by characters represented by them |
| 509 |
|
(or an empty string if <code>\</code> is immediately followed by |
| 510 |
|
newline character(s)) respectively.</li> |
| 511 |
|
<li>Remove the quotation characters in <var>s</var> |
| 512 |
|
if <var>s</var> is a <code>STRING</code>.</li> |
| 513 |
|
<li>If there is any character that is <em>not</em> one of |
| 514 |
|
<code class=char>U+0020</code> <code class=charname>SPACE</code>, |
| 515 |
|
<code class=char>U+0021</code> <code class=charname>EXCLAMATION MARK</code> |
| 516 |
|
(<code class=char>!</code>), <code class=char>U+0023</code> |
| 517 |
|
<code class=charname>NUMBER SIGN</code> (<code class=char>#</code>) to |
| 518 |
|
<code class=char>U+005B</code> <code class=charname>LEFT SQUARE |
| 519 |
|
BRACKET</code>, <code class=char>U+005D</code> <code class=charname>RIGHT |
| 520 |
|
SQUARE BRACKET</code> to <code class=char>U+D7FF</code>, or |
| 521 |
|
<code class=char>U+E000</code> to <code class=char>U+10FFFF</code> in |
| 522 |
|
<var>s</var>, then replace it by string <code>\<var>HHHHHH</var></code>, where |
| 523 |
|
<dfn id=var-HHHHHH><var>HHHHHH</var></dfn> is the upper$B!>(Bcase zero$B!>(Bpadded |
| 524 |
|
hexadecimal representation of the character. If the character |
| 525 |
|
is outside the range of <code>[<code class=char>U+0000</code>, |
| 526 |
|
<code class=char>U+10FFFF</code>]</code>, <var>HHHHHH</var> |
| 527 |
|
<em class=rfc2119>MUST</em> be <code>FFFFFF</code>.</li> |
| 528 |
|
<li>Insert a <code class=char>U+0022</code> <code class=charname>QUOTATION |
| 529 |
|
MARK</code> (<code class=char>"</code>) at the beginning of <var>s</var>.</li> |
| 530 |
|
<li>Insert a <code class=char>U+0022</code> <code class=charname>QUOTATION |
| 531 |
|
MARK</code> (<code class=char>"</code>) at the end of <var>s</var>.</li> |
| 532 |
|
<li>Then, <var>s</var> is the result of the algorithm.</li> |
| 533 |
|
</ol> |
| 534 |
|
|
| 535 |
<p>A <dfn id=newline title=newline>newline</dfn> |
<p>A <dfn id=newline title=newline>newline</dfn> |
| 536 |
<em class=rfc2119>SHOULD</em> be represented as a |
<em class=rfc2119>SHOULD</em> be represented as a |
| 540 |
representation is in use, a sequence of |
representation is in use, a sequence of |
| 541 |
<code class=char>U+000D</code> <code class=charname>CARRIAGE RETURN</code> |
<code class=char>U+000D</code> <code class=charname>CARRIAGE RETURN</code> |
| 542 |
followed by a <code class=char>U+000A</code> |
followed by a <code class=char>U+000A</code> |
| 543 |
<code class=charname>LINE FEED</code> or a character |
<code class=charname>LINE FEED</code> (i.e. a |
| 544 |
|
<code>CRLF</code> sequence) or a character |
| 545 |
<code class=char>U+000D</code> <code class=charname>CARRIAGE RETURN</code> |
<code class=char>U+000D</code> <code class=charname>CARRIAGE RETURN</code> |
| 546 |
<em class=rfc2119>MAY</em> be used as a newline instead.</p> |
<em class=rfc2119>MAY</em> be used as a <a href="#newline">newline</a> instead. |
| 547 |
|
<a href="#newline">Newline</a> representations |
| 548 |
|
<em class=rfc2119>SHOULD</em> be consistent in an |
| 549 |
|
<abbr title="Selectors Serialization Format for Testing">SSFT</abbr> |
| 550 |
|
representation.</p> |
| 551 |
|
|
| 552 |
<div class="note memo"> |
<div class="note memo"> |
| 553 |
<p>Therefore, when |
<p>Therefore, newlines must be normalized before |
| 554 |
<abbr title="Selectors Serialization Format for Testing">SSFT</abbr> |
<abbr title="Selectors Serialization Format for Testing">SSFT</abbr> |
| 555 |
representations are literally compared, newlines must be normalized.</p> |
representations are literally compared.</p> |
| 556 |
</div> |
</div> |
| 557 |
|
|
| 558 |
</div> |
</div> |
| 649 |
<code class=URI><<a href="http://dev.w3.org/2006/webapi/selectors-api/Overview.html">http://dev.w3.org/2006/webapi/selectors-api/Overview.html</a>></code>. |
<code class=URI><<a href="http://dev.w3.org/2006/webapi/selectors-api/Overview.html">http://dev.w3.org/2006/webapi/selectors-api/Overview.html</a>></code>. |
| 650 |
The latest published version of the specification is available at |
The latest published version of the specification is available at |
| 651 |
<code class=URI><<a href="http://www.w3.org/TR/selectors-api/">http://www.w3.org/TR/selectors-api/</a>></code>.</dd> |
<code class=URI><<a href="http://www.w3.org/TR/selectors-api/">http://www.w3.org/TR/selectors-api/</a>></code>.</dd> |
| 652 |
<dt id=XBL2>XBL2</dt> |
<dt id=ref-XBL2>XBL2</dt> |
| 653 |
<dd><cite><a href="http://www.mozilla.org/projects/xbl/xbl2.html"><abbr>XBL</abbr> |
<dd><cite><a href="http://www.mozilla.org/projects/xbl/xbl2.html"><abbr>XBL</abbr> |
| 654 |
2.0</a></cite>, Mozilla.org, <time datetime=2007-03-15>15 Mar 2007</time>. |
2.0</a></cite>, Mozilla.org, <time datetime=2007-03-15>15 Mar 2007</time>. |
| 655 |
Work in progress. The latest |
Work in progress. The latest |