Skip to content

Commit

Permalink
Give host parser a suitable default for the HTML Standard
Browse files Browse the repository at this point in the history
HTML invokes it without a second argument and expects it to special by default.
  • Loading branch information
annevk authored May 30, 2018
1 parent 5e58d1d commit ac532ae
Showing 1 changed file with 18 additions and 16 deletions.
34 changes: 18 additions & 16 deletions url.bs
Original file line number Diff line number Diff line change
Expand Up @@ -358,10 +358,12 @@ requires context to be distinguished.

<h3 id=host-parsing>Host parsing</h3>

<p>The <dfn id=concept-host-parser>host parser</dfn> takes a string <var>input</var>, a boolean
<var>isSpecial</var>, and then runs these steps:
<p>The <dfn export id=concept-host-parser lt="host parser|host parsing">host parser</dfn> takes a
string <var>input</var> with an optional boolean <var>isNotSpecial</var>, and then runs these steps:

<ol>
<li><p>If <var>isNotSpecial</var> is not given, then set <var>isNotSpecial</var> to false.

<li>

This comment has been minimized.

Copy link
@GPHemsley

GPHemsley Jun 24, 2018

Member

If HTML invokes this without a second argument, why bother changing the variable name? Why not just change the default value?

Writing it this way means callers using the second variable have to say isNotSpecial = false to mean "is special", which can be hard for the human brain to process.

This comment has been minimized.

Copy link
@annevk

annevk Jun 24, 2018

Author Member

Because arguments defaulting to true are wrong.

This comment has been minimized.

Copy link
@GPHemsley

GPHemsley Jun 24, 2018

Member

That's a strong statement to make without any supporting evidence. Mind providing some context?

This comment has been minimized.

Copy link
@annevk

This comment has been minimized.

Copy link
@GPHemsley

GPHemsley Jun 27, 2018

Member

That seems to make both of our points, so perhaps this warrants a full discussion. I'll open up an issue.

<p>If <var>input</var> starts with U+005B ([), then:

Expand All @@ -372,7 +374,7 @@ requires context to be distinguished.
leading U+005B ([) and trailing U+005D (]) removed.
</ol>

<li><p>If <var>isSpecial</var> is false, then return the result of
<li><p>If <var>isNotSpecial</var> is true, then return the result of
<a lt="opaque-host parser">opaque-host parsing</a> <var>input</var>.

<li>
Expand Down Expand Up @@ -1036,7 +1038,8 @@ corresponding <a for=url>port</a> and is listed in the second column on the same
elsewhere though. -->

<p>A <a for=/>URL</a> <dfn export>is special</dfn> if its <a for=url>scheme</a> is a
<a>special scheme</a>.
<a>special scheme</a>. A <a for=/>URL</a> <dfn>is not special</dfn> if its <a for=url>scheme</a> is
not a <a>special scheme</a>.

<p>A <a for=/>URL</a>
<dfn export lt="include credentials|includes credentials">includes credentials</dfn> if its
Expand Down Expand Up @@ -1715,8 +1718,8 @@ string <var>input</var>, optionally with a <a>base URL</a> <var>base</var>, opti
<li><p>If <var>buffer</var> is the empty string, <a>validation error</a>, return failure.
<!-- No URLs with port, but without host. -->

<li><p>Let <var>host</var> be the result of <a lt="host parser">host parsing</a>
<var>buffer</var> with <var>url</var> <a>is special</a>.
<li><p>Let <var>host</var> be the result of <a>host parsing</a> <var>buffer</var> with
<var>url</var> <a>is not special</a>.

<li><p>If <var>host</var> is failure, then return failure.

Expand Down Expand Up @@ -1748,8 +1751,8 @@ string <var>input</var>, optionally with a <a>base URL</a> <var>base</var>, opti
string, and either <var>url</var> <a>includes credentials</a> or <var>url</var>'s
<a for=url>port</a> is non-null, <a>validation error</a>, return.

<li><p>Let <var>host</var> be the result of <a lt="host parser">host parsing</a>
<var>buffer</var> with <var>url</var> <a>is special</a>.
<li><p>Let <var>host</var> be the result of <a>host parsing</a> <var>buffer</var> with
<var>url</var> <a>is not special</a>.

<li><p>If <var>host</var> is failure, then return failure.

Expand Down Expand Up @@ -1946,8 +1949,8 @@ string <var>input</var>, optionally with a <a>base URL</a> <var>base</var>, opti
<p>Otherwise, run these steps:

<ol>
<li><p>Let <var>host</var> be the result of <a lt="host parser">host parsing</a>
<var>buffer</var> with <var>url</var> <a>is special</a>.
<li><p>Let <var>host</var> be the result of <a>host parsing</a> <var>buffer</var> with
<var>url</var> <a>is not special</a>.

<li><p>If <var>host</var> is failure, then return failure.

Expand Down Expand Up @@ -2109,7 +2112,7 @@ string <var>input</var>, optionally with a <a>base URL</a> <var>base</var>, opti
<p>If <var>encoding</var> is not <a>UTF-8</a> and one of the following is true

<ul class=brief>
<li><p><var>url</var> <a lt="is special">is not special</a>
<li><p><var>url</var> <a>is not special</a>
<li><p><var>url</var>'s <a for=url>scheme</a> is "<code>ws</code>" or "<code>wss</code>"
</ul>

Expand Down Expand Up @@ -2603,14 +2606,13 @@ URLPath would be a subclassed Array? -->
<li><p>Let <var>parsedBase</var> be the result of running the <a>basic URL parser</a> on
<var>base</var>.

<li><p>If <var>parsedBase</var> is failure, then <a>throw</a> a <code>TypeError</code> exception.
<li><p>If <var>parsedBase</var> is failure, then <a>throw</a> a {{TypeError}}.
</ol>

<li><p>Let <var>parsedURL</var> be the result of running the <a>basic URL parser</a> on
<var>url</var> with <var>parsedBase</var>.

<li><p>If <var>parsedURL</var> is failure, <a>throw</a> a <code>TypeError</code>
exception.
<li><p>If <var>parsedURL</var> is failure, then <a>throw</a> a {{TypeError}}.

<li><p>Let <var>query</var> be <var>parsedURL</var>'s <a for=url>query</a>, if that is non-null,
and the empty string otherwise.
Expand Down Expand Up @@ -2671,7 +2673,7 @@ url.pathname // "/%F0%9F%8F%B3%EF%B8%8F%E2%80%8D%F0%9F%8C%88"</code></pre>
<li><p>Let <var>parsedURL</var> be the result of running the <a>basic URL parser</a> on the given
value.

<li><p>If <var>parsedURL</var> is failure, <a>throw</a> a <code>TypeError</code> exception.
<li><p>If <var>parsedURL</var> is failure, then <a>throw</a> a {{TypeError}}.

<li><p>Set <a>context object</a>'s <a for=URL>url</a> to <var>parsedURL</var>.

Expand Down Expand Up @@ -3064,7 +3066,7 @@ these steps:
<a for=URLSearchParams>list</a> name-value pairs with the key being
the name and the value being the value.

<p>The <dfn dfn for=URLSearchParams>stringification behavior</dfn> must return the
<p>The <dfn for=URLSearchParams>stringification behavior</dfn> must return the
<a lt='urlencoded serializer'>serialization</a> of the {{URLSearchParams}} object's
<a for=URLSearchParams>list</a>.

Expand Down

2 comments on commit ac532ae

@GPHemsley
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It appears there are some unrelated editorial changes in here.

@annevk
Copy link
Member Author

@annevk annevk commented on ac532ae Jun 24, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That's fairly typical.

Please sign in to comment.