<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<!DOCTYPE bugzilla SYSTEM "https://bugs.webkit.org/page.cgi?id=bugzilla.dtd">

<bugzilla version="5.0.4.1"
          urlbase="https://bugs.webkit.org/"
          
          maintainer="admin@webkit.org"
>

    <bug>
          <bug_id>167154</bug_id>
          
          <creation_ts>2017-01-18 00:06:49 -0800</creation_ts>
          <short_desc>Implement URLSearchParams&apos;s sort()</short_desc>
          <delta_ts>2017-01-18 23:46:59 -0800</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>1</classification_id>
          <classification>Unclassified</classification>
          <product>WebKit</product>
          <component>DOM</component>
          <version>Safari Technology Preview</version>
          <rep_platform>Unspecified</rep_platform>
          <op_sys>Unspecified</op_sys>
          <bug_status>RESOLVED</bug_status>
          <resolution>FIXED</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P2</priority>
          <bug_severity>Normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Anne van Kesteren">annevk</reporter>
          <assigned_to name="Alex Christensen">achristensen</assigned_to>
          <cc>achristensen</cc>
    
    <cc>cdumez</cc>
    
    <cc>commit-queue</cc>
    
    <cc>esprehn+autocc</cc>
    
    <cc>gyuyoung.kim</cc>
    
    <cc>kondapallykalyan</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>1267683</commentid>
    <comment_count>0</comment_count>
    <who name="Anne van Kesteren">annevk</who>
    <bug_when>2017-01-18 00:06:49 -0800</bug_when>
    <thetext>See https://w3c-test.org/url/urlsearchparams-sort.html for a test, https://github.com/whatwg/url/issues/26 for discussion, and https://url.spec.whatwg.org/#dom-urlsearchparams-sort for the standard.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1267968</commentid>
    <comment_count>1</comment_count>
      <attachid>299208</attachid>
    <who name="Alex Christensen">achristensen</who>
    <bug_when>2017-01-18 18:19:25 -0800</bug_when>
    <thetext>Created attachment 299208
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1267974</commentid>
    <comment_count>2</comment_count>
    <who name="Alex Christensen">achristensen</who>
    <bug_when>2017-01-18 18:30:04 -0800</bug_when>
    <thetext>By the way, Anne, all the existing tests pass if I use std::sort instead of std::stable_sort.  I would suggest adding a longer test like this to the web platform tests to verify the stability of sorting algorithms:

  {
    &quot;input&quot;: &quot;z=z&amp;a=a&amp;z=y&amp;a=b&amp;z=x&amp;a=c&amp;z=w&amp;a=d&amp;z=v&amp;a=e&amp;z=u&amp;a=f&amp;z=t&amp;a=g&quot;,
    &quot;output&quot;: [[&quot;a&quot;, &quot;a&quot;], [&quot;a&quot;, &quot;b&quot;], [&quot;a&quot;, &quot;c&quot;], [&quot;a&quot;, &quot;d&quot;], [&quot;a&quot;, &quot;e&quot;], [&quot;a&quot;, &quot;f&quot;], [&quot;a&quot;, &quot;g&quot;], [&quot;z&quot;, &quot;z&quot;], [&quot;z&quot;, &quot;y&quot;], [&quot;z&quot;, &quot;x&quot;], [&quot;z&quot;, &quot;w&quot;], [&quot;z&quot;, &quot;v&quot;], [&quot;z&quot;, &quot;u&quot;], [&quot;z&quot;, &quot;t&quot;]]
  },</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1267980</commentid>
    <comment_count>3</comment_count>
      <attachid>299208</attachid>
    <who name="Sam Weinig">sam</who>
    <bug_when>2017-01-18 18:41:48 -0800</bug_when>
    <thetext>Comment on attachment 299208
Patch

View in context: https://bugs.webkit.org/attachment.cgi?id=299208&amp;action=review

&gt; Source/WebCore/html/URLSearchParams.cpp:64
&gt; +    std::stable_sort(m_pairs.begin(), m_pairs.end(), [] (auto a, auto b) {

Can we add some type of modifier to these autos as I am not sure if this is causing copying / a.k.a. ref-churn for each lambda call.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1268051</commentid>
    <comment_count>4</comment_count>
    <who name="Anne van Kesteren">annevk</who>
    <bug_when>2017-01-18 23:27:47 -0800</bug_when>
    <thetext>Alex: https://github.com/w3c/web-platform-tests/pull/4563 (feel free to create them yourself next time).

Also, I&apos;m curious, since I did try to test for stable sort, when does the difference happen? Or does it vary on implementation strategy?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1268054</commentid>
    <comment_count>5</comment_count>
    <who name="Alex Christensen">achristensen</who>
    <bug_when>2017-01-18 23:39:30 -0800</bug_when>
    <thetext>(In reply to comment #4)
&gt; Alex: https://github.com/w3c/web-platform-tests/pull/4563 (feel free to
&gt; create them yourself next time).
I&apos;m going to get better at this
&gt; 
&gt; Also, I&apos;m curious, since I did try to test for stable sort, when does the
&gt; difference happen? Or does it vary on implementation strategy?
I think it&apos;s stl-implementation dependent.  I think our stl implementation is from libc++ and it definitely passed all the existing tests with std::sort but the longer test failed unless it used std::stable_sort.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1268055</commentid>
    <comment_count>6</comment_count>
    <who name="Alex Christensen">achristensen</who>
    <bug_when>2017-01-18 23:46:59 -0800</bug_when>
    <thetext>http://trac.webkit.org/r210915</thetext>
  </long_desc>
      
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>299208</attachid>
            <date>2017-01-18 18:19:25 -0800</date>
            <delta_ts>2017-01-18 18:41:48 -0800</delta_ts>
            <desc>Patch</desc>
            <filename>bug-167154-20170118181735.patch</filename>
            <type>text/plain</type>
            <size>5389</size>
            <attacher name="Alex Christensen">achristensen</attacher>
            
              <data encoding="base64">SW5kZXg6IFNvdXJjZS9XZWJDb3JlL0NoYW5nZUxvZwo9PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tLSBTb3VyY2UvV2Vi
Q29yZS9DaGFuZ2VMb2cJKHJldmlzaW9uIDIxMDkwMykKKysrIFNvdXJjZS9XZWJDb3JlL0NoYW5n
ZUxvZwkod29ya2luZyBjb3B5KQpAQCAtMSwzICsxLDE3IEBACisyMDE3LTAxLTE4ICBBbGV4IENo
cmlzdGVuc2VuICA8YWNocmlzdGVuc2VuQHdlYmtpdC5vcmc+CisKKyAgICAgICAgSW1wbGVtZW50
IFVSTFNlYXJjaFBhcmFtcydzIHNvcnQoKQorICAgICAgICBodHRwczovL2J1Z3Mud2Via2l0Lm9y
Zy9zaG93X2J1Zy5jZ2k/aWQ9MTY3MTU0CisKKyAgICAgICAgUmV2aWV3ZWQgYnkgTk9CT0RZIChP
T1BTISkuCisKKyAgICAgICAgVGVzdDogaW1wb3J0ZWQvdzNjL3dlYi1wbGF0Zm9ybS10ZXN0cy91
cmwvdXJsc2VhcmNocGFyYW1zLXNvcnQuaHRtbAorCisgICAgICAgICogaHRtbC9VUkxTZWFyY2hQ
YXJhbXMuY3BwOgorICAgICAgICAoV2ViQ29yZTo6VVJMU2VhcmNoUGFyYW1zOjpzb3J0KToKKyAg
ICAgICAgKiBodG1sL1VSTFNlYXJjaFBhcmFtcy5oOgorICAgICAgICAqIGh0bWwvVVJMU2VhcmNo
UGFyYW1zLmlkbDoKKwogMjAxNy0wMS0xOCAgUnlhbiBIYWRkYWQgIDxyeWFuaGFkZGFkQGFwcGxl
LmNvbT4KIAogICAgICAgICBVbnJldmlld2VkLCByb2xsaW5nIG91dCByMjEwODQ4LgpJbmRleDog
U291cmNlL1dlYkNvcmUvaHRtbC9VUkxTZWFyY2hQYXJhbXMuY3BwCj09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KLS0tIFNv
dXJjZS9XZWJDb3JlL2h0bWwvVVJMU2VhcmNoUGFyYW1zLmNwcAkocmV2aXNpb24gMjEwODg5KQor
KysgU291cmNlL1dlYkNvcmUvaHRtbC9VUkxTZWFyY2hQYXJhbXMuY3BwCSh3b3JraW5nIGNvcHkp
CkBAIC01OSw2ICs1OSwxNCBAQCBib29sIFVSTFNlYXJjaFBhcmFtczo6aGFzKGNvbnN0IFN0cmlu
ZyYgCiAgICAgcmV0dXJuIGZhbHNlOwogfQogCit2b2lkIFVSTFNlYXJjaFBhcmFtczo6c29ydCgp
Cit7CisgICAgc3RkOjpzdGFibGVfc29ydChtX3BhaXJzLmJlZ2luKCksIG1fcGFpcnMuZW5kKCks
IFtdIChhdXRvIGEsIGF1dG8gYikgeworICAgICAgICByZXR1cm4gV1RGOjpjb2RlUG9pbnRDb21w
YXJlTGVzc1RoYW4oYS5maXJzdCwgYi5maXJzdCk7CisgICAgfSk7CisgICAgdXBkYXRlVVJMKCk7
Cit9CisKIHZvaWQgVVJMU2VhcmNoUGFyYW1zOjpzZXQoY29uc3QgU3RyaW5nJiBuYW1lLCBjb25z
dCBTdHJpbmcmIHZhbHVlKQogewogICAgIGZvciAoYXV0byYgcGFpciA6IG1fcGFpcnMpIHsKSW5k
ZXg6IFNvdXJjZS9XZWJDb3JlL2h0bWwvVVJMU2VhcmNoUGFyYW1zLmgKPT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQotLS0g
U291cmNlL1dlYkNvcmUvaHRtbC9VUkxTZWFyY2hQYXJhbXMuaAkocmV2aXNpb24gMjEwODg5KQor
KysgU291cmNlL1dlYkNvcmUvaHRtbC9VUkxTZWFyY2hQYXJhbXMuaAkod29ya2luZyBjb3B5KQpA
QCAtNDcsNiArNDcsNyBAQCBwdWJsaWM6CiAgICAgY29uc3QgVmVjdG9yPHN0ZDo6cGFpcjxTdHJp
bmcsIFN0cmluZz4+JiBwYWlycygpIGNvbnN0IHsgcmV0dXJuIG1fcGFpcnM7IH0KICAgICBvcGVy
YXRvciBjb25zdCBWZWN0b3I8c3RkOjpwYWlyPFN0cmluZywgU3RyaW5nPj4mKCkgeyByZXR1cm4g
bV9wYWlyczsgfQogICAgIHZvaWQgdXBkYXRlRnJvbUFzc29jaWF0ZWRVUkwoKTsKKyAgICB2b2lk
IHNvcnQoKTsKIAogICAgIGNsYXNzIEl0ZXJhdG9yIHsKICAgICBwdWJsaWM6CkluZGV4OiBTb3Vy
Y2UvV2ViQ29yZS9odG1sL1VSTFNlYXJjaFBhcmFtcy5pZGwKPT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQotLS0gU291cmNl
L1dlYkNvcmUvaHRtbC9VUkxTZWFyY2hQYXJhbXMuaWRsCShyZXZpc2lvbiAyMTA4ODkpCisrKyBT
b3VyY2UvV2ViQ29yZS9odG1sL1VSTFNlYXJjaFBhcmFtcy5pZGwJKHdvcmtpbmcgY29weSkKQEAg
LTM0LDYgKzM0LDkgQEAKICAgICBzZXF1ZW5jZTxVU1ZTdHJpbmc+IGdldEFsbChVU1ZTdHJpbmcg
bmFtZSk7CiAgICAgYm9vbGVhbiBoYXMoVVNWU3RyaW5nIG5hbWUpOwogICAgIHZvaWQgc2V0KFVT
VlN0cmluZyBuYW1lLCBVU1ZTdHJpbmcgdmFsdWUpOworCisgICAgdm9pZCBzb3J0KCk7CisKICAg
ICBpdGVyYWJsZTxVU1ZTdHJpbmcsIFVTVlN0cmluZz47CiAKICAgICAvLyBGSVhNRTogVGhpcyBz
aG91bGQganVzdCBiZSBzdHJpbmdpZmllciBvbmNlIHRoYXQgaXMgc3VwcG9ydGVkIGluIHRoZSBi
aW5kaW5ncyBnZW5lcmF0b3IKSW5kZXg6IExheW91dFRlc3RzL2ltcG9ydGVkL3czYy9DaGFuZ2VM
b2cKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PQotLS0gTGF5b3V0VGVzdHMvaW1wb3J0ZWQvdzNjL0NoYW5nZUxvZwkocmV2
aXNpb24gMjEwOTAzKQorKysgTGF5b3V0VGVzdHMvaW1wb3J0ZWQvdzNjL0NoYW5nZUxvZwkod29y
a2luZyBjb3B5KQpAQCAtMSwzICsxLDEzIEBACisyMDE3LTAxLTE4ICBBbGV4IENocmlzdGVuc2Vu
ICA8YWNocmlzdGVuc2VuQHdlYmtpdC5vcmc+CisKKyAgICAgICAgSW1wbGVtZW50IFVSTFNlYXJj
aFBhcmFtcydzIHNvcnQoKQorICAgICAgICBodHRwczovL2J1Z3Mud2Via2l0Lm9yZy9zaG93X2J1
Zy5jZ2k/aWQ9MTY3MTU0CisKKyAgICAgICAgUmV2aWV3ZWQgYnkgTk9CT0RZIChPT1BTISkuCisK
KyAgICAgICAgKiB3ZWItcGxhdGZvcm0tdGVzdHMvdXJsL3VybHNlYXJjaHBhcmFtcy1zb3J0LWV4
cGVjdGVkLnR4dDogQWRkZWQuCisgICAgICAgICogd2ViLXBsYXRmb3JtLXRlc3RzL3VybC91cmxz
ZWFyY2hwYXJhbXMtc29ydC5odG1sOiBBZGRlZC4KKwogMjAxNy0wMS0xOCAgWW91ZW5uIEZhYmxl
dCAgPHlvdWVubkBhcHBsZS5jb20+CiAKICAgICAgICAgUmVqZWN0IGZldGNoIHByb21pc2UgaW4g
Y2FzZSBvZiBSZWFkYWJsZVN0cmVhbSB1cGxvYWQKSW5kZXg6IExheW91dFRlc3RzL2ltcG9ydGVk
L3czYy93ZWItcGxhdGZvcm0tdGVzdHMvdXJsL3VybHNlYXJjaHBhcmFtcy1zb3J0LWV4cGVjdGVk
LnR4dAo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09Ci0tLSBMYXlvdXRUZXN0cy9pbXBvcnRlZC93M2Mvd2ViLXBsYXRmb3Jt
LXRlc3RzL3VybC91cmxzZWFyY2hwYXJhbXMtc29ydC1leHBlY3RlZC50eHQJKG5vbmV4aXN0ZW50
KQorKysgTGF5b3V0VGVzdHMvaW1wb3J0ZWQvdzNjL3dlYi1wbGF0Zm9ybS10ZXN0cy91cmwvdXJs
c2VhcmNocGFyYW1zLXNvcnQtZXhwZWN0ZWQudHh0CSh3b3JraW5nIGNvcHkpCkBAIC0wLDAgKzEs
MTAgQEAKKworUEFTUyBQYXJzZSBhbmQgc29ydDogej1iJmE9YiZ6PWEmYT1hIAorUEFTUyBVUkwg
cGFyc2UgYW5kIHNvcnQ6IHo9YiZhPWImej1hJmE9YSAKK1BBU1MgUGFyc2UgYW5kIHNvcnQ6IO+/
vT14Ju+/vCbvv709YSAKK1BBU1MgVVJMIHBhcnNlIGFuZCBzb3J0OiDvv709eCbvv7wm77+9PWEg
CitQQVNTIFBhcnNlIGFuZCBzb3J0OiDvrIMm8J+MiCAKK1BBU1MgVVJMIHBhcnNlIGFuZCBzb3J0
OiDvrIMm8J+MiCAKK1BBU1MgUGFyc2UgYW5kIHNvcnQ6IMOpJmXvv70mZcyBIAorUEFTUyBVUkwg
cGFyc2UgYW5kIHNvcnQ6IMOpJmXvv70mZcyBIAorCkluZGV4OiBMYXlvdXRUZXN0cy9pbXBvcnRl
ZC93M2Mvd2ViLXBsYXRmb3JtLXRlc3RzL3VybC91cmxzZWFyY2hwYXJhbXMtc29ydC5odG1sCj09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT0KLS0tIExheW91dFRlc3RzL2ltcG9ydGVkL3czYy93ZWItcGxhdGZvcm0tdGVzdHMv
dXJsL3VybHNlYXJjaHBhcmFtcy1zb3J0Lmh0bWwJKG5vbmV4aXN0ZW50KQorKysgTGF5b3V0VGVz
dHMvaW1wb3J0ZWQvdzNjL3dlYi1wbGF0Zm9ybS10ZXN0cy91cmwvdXJsc2VhcmNocGFyYW1zLXNv
cnQuaHRtbAkod29ya2luZyBjb3B5KQpAQCAtMCwwICsxLDQ2IEBACis8IWRvY3R5cGUgaHRtbD4K
KzxtZXRhIGNoYXJzZXQ9InV0ZjgiPgorPHNjcmlwdCBzcmM9Ii9yZXNvdXJjZXMvdGVzdGhhcm5l
c3MuanMiPjwvc2NyaXB0PgorPHNjcmlwdCBzcmM9Ii9yZXNvdXJjZXMvdGVzdGhhcm5lc3NyZXBv
cnQuanMiPjwvc2NyaXB0PgorPGRpdiBpZD1sb2c+PC9kaXY+Cis8c2NyaXB0PgorWworICB7Cisg
ICAgImlucHV0IjogIno9YiZhPWImej1hJmE9YSIsCisgICAgIm91dHB1dCI6IFtbImEiLCAiYiJd
LCBbImEiLCAiYSJdLCBbInoiLCAiYiJdLCBbInoiLCAiYSJdXQorICB9LAorICB7CisgICAgImlu
cHV0IjogIlx1RkZGRD14Jlx1RkZGQyZcdUZGRkQ9YSIsCisgICAgIm91dHB1dCI6IFtbIlx1RkZG
QyIsICIiXSwgWyJcdUZGRkQiLCAieCJdLCBbIlx1RkZGRCIsICJhIl1dCisgIH0sCisgIHsKKyAg
ICAiaW5wdXQiOiAi76yDJvCfjIgiLCAvLyDwn4yIID4gY29kZSBwb2ludCwgYnV0IDwgY29kZSB1
bml0IGJlY2F1c2UgdHdvIGNvZGUgdW5pdHMKKyAgICAib3V0cHV0IjogW1si8J+MiCIsICIiXSwg
WyLvrIMiLCAiIl1dCisgIH0sCisgIHsKKyAgICAiaW5wdXQiOiAiw6kmZVx1RkZGRCZlXHUwMzAx
IiwKKyAgICAib3V0cHV0IjogW1siZVx1MDMwMSIsICIiXSwgWyJlXHVGRkZEIiwgIiJdLCBbIsOp
IiwgIiJdXQorICB9CitdLmZvckVhY2goKHZhbCkgPT4geworICB0ZXN0KCgpID0+IHsKKyAgICBs
ZXQgcGFyYW1zID0gbmV3IFVSTFNlYXJjaFBhcmFtcyh2YWwuaW5wdXQpLAorICAgICAgICBpID0g
MAorICAgIHBhcmFtcy5zb3J0KCkKKyAgICBmb3IobGV0IHBhcmFtIG9mIHBhcmFtcykgeworICAg
ICAgYXNzZXJ0X2FycmF5X2VxdWFscyhwYXJhbSwgdmFsLm91dHB1dFtpXSkKKyAgICAgIGkrKwor
ICAgIH0KKyAgfSwgIlBhcnNlIGFuZCBzb3J0OiAiICsgdmFsLmlucHV0KQorCisgIHRlc3QoKCkg
PT4geworICAgIGxldCB1cmwgPSBuZXcgVVJMKCI/IiArIHZhbC5pbnB1dCwgImh0dHBzOi8vZXhh
bXBsZS8iKQorICAgIHVybC5zZWFyY2hQYXJhbXMuc29ydCgpCisgICAgbGV0IHBhcmFtcyA9IG5l
dyBVUkxTZWFyY2hQYXJhbXModXJsLnNlYXJjaCksCisgICAgICAgIGkgPSAwCisgICAgZm9yKGxl
dCBwYXJhbSBvZiBwYXJhbXMpIHsKKyAgICAgIGFzc2VydF9hcnJheV9lcXVhbHMocGFyYW0sIHZh
bC5vdXRwdXRbaV0pCisgICAgICBpKysKKyAgICB9CisgIH0sICJVUkwgcGFyc2UgYW5kIHNvcnQ6
ICIgKyB2YWwuaW5wdXQpCit9KQorPC9zY3JpcHQ+Cg==
</data>
<flag name="review"
          id="321194"
          type_id="1"
          status="+"
          setter="sam"
    />
          </attachment>
      

    </bug>

</bugzilla>