<?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>229886</bug_id>
          
          <creation_ts>2021-09-03 12:40:16 -0700</creation_ts>
          <short_desc>Regression(r277571) Call to SQLiteDatabase::turnOnIncrementalAutoVacuum() from ITP fails</short_desc>
          <delta_ts>2023-07-18 09:02:48 -0700</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>1</classification_id>
          <classification>Unclassified</classification>
          <product>WebKit</product>
          <component>WebCore Misc.</component>
          <version>WebKit Nightly Build</version>
          <rep_platform>Unspecified</rep_platform>
          <op_sys>Unspecified</op_sys>
          <bug_status>RESOLVED</bug_status>
          <resolution>FIXED</resolution>
          
          <see_also>https://bugs.webkit.org/show_bug.cgi?id=259284</see_also>
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords>InRadar</keywords>
          <priority>P2</priority>
          <bug_severity>Normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Chris Dumez">cdumez</reporter>
          <assigned_to name="Chris Dumez">cdumez</assigned_to>
          <cc>achristensen</cc>
    
    <cc>darin</cc>
    
    <cc>ggaren</cc>
    
    <cc>katherine_cheney</cc>
    
    <cc>sam</cc>
    
    <cc>webkit-bug-importer</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>1790293</commentid>
    <comment_count>0</comment_count>
    <who name="Chris Dumez">cdumez</who>
    <bug_when>2021-09-03 12:40:16 -0700</bug_when>
    <thetext>Call to SQLiteDatabase::turnOnIncrementalAutoVacuum() from ITP fails since r277571 and logs:
0x104de9900 - ResourceLoadStatisticsDatabaseStore::turnOnIncrementalAutoVacuum failed, error message: not an error</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1790295</commentid>
    <comment_count>1</comment_count>
    <who name="Chris Dumez">cdumez</who>
    <bug_when>2021-09-03 12:40:33 -0700</bug_when>
    <thetext>&lt;rdar://82581507&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1790299</commentid>
    <comment_count>2</comment_count>
      <attachid>437299</attachid>
    <who name="Chris Dumez">cdumez</who>
    <bug_when>2021-09-03 12:44:32 -0700</bug_when>
    <thetext>Created attachment 437299
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1790339</commentid>
    <comment_count>3</comment_count>
      <attachid>437299</attachid>
    <who name="Darin Adler">darin</who>
    <bug_when>2021-09-03 13:42:43 -0700</bug_when>
    <thetext>Comment on attachment 437299
Patch

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

&gt; Source/WebCore/platform/sql/SQLiteDatabase.cpp:630
&gt;      int autoVacuumMode = 0;
&gt; -    if (auto statement = prepareStatement(&quot;PRAGMA auto_vacuum&quot;_s))
&gt; +    int error = 0;
&gt; +    if (auto statement = prepareStatement(&quot;PRAGMA auto_vacuum&quot;_s)) {
&gt;          autoVacuumMode = statement-&gt;columnInt(0);
&gt; -    int error = lastError();
&gt; +        error = lastError();
&gt; +    }

Seems like we can straighten out the logic a little. If we can’t prepare the statement, we return false, but for some reason we implement that by setting error to &quot;0&quot; and then comparing it with SQLITE_ROW. I would write:

    auto statement = prepareStatement(&quot;PRAGMA auto_vacuum&quot;_s);
    if (!statement)
        return false;

    // &lt;Move here and/or improve long confusing comment about error codes that does not even mention SQLITE_ROW&gt;?
    auto autoVacuumMode = statement-&gt;columnInt(0); 
    if (lastError() != SQLITE_ROW)
        return false;

I like that better than having a local variable named error. The code below also doesn’t need a local variable.

    return lastError() == SQLITE_OK;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1790340</commentid>
    <comment_count>4</comment_count>
    <who name="Chris Dumez">cdumez</who>
    <bug_when>2021-09-03 13:44:26 -0700</bug_when>
    <thetext>(In reply to Darin Adler from comment #3)
&gt; Comment on attachment 437299 [details]
&gt; Patch
&gt; 
&gt; View in context:
&gt; https://bugs.webkit.org/attachment.cgi?id=437299&amp;action=review
&gt; 
&gt; &gt; Source/WebCore/platform/sql/SQLiteDatabase.cpp:630
&gt; &gt;      int autoVacuumMode = 0;
&gt; &gt; -    if (auto statement = prepareStatement(&quot;PRAGMA auto_vacuum&quot;_s))
&gt; &gt; +    int error = 0;
&gt; &gt; +    if (auto statement = prepareStatement(&quot;PRAGMA auto_vacuum&quot;_s)) {
&gt; &gt;          autoVacuumMode = statement-&gt;columnInt(0);
&gt; &gt; -    int error = lastError();
&gt; &gt; +        error = lastError();
&gt; &gt; +    }
&gt; 
&gt; Seems like we can straighten out the logic a little. If we can’t prepare the
&gt; statement, we return false, but for some reason we implement that by setting
&gt; error to &quot;0&quot; and then comparing it with SQLITE_ROW. I would write:
&gt; 
&gt;     auto statement = prepareStatement(&quot;PRAGMA auto_vacuum&quot;_s);
&gt;     if (!statement)
&gt;         return false;
&gt; 
&gt;     // &lt;Move here and/or improve long confusing comment about error codes
&gt; that does not even mention SQLITE_ROW&gt;?
&gt;     auto autoVacuumMode = statement-&gt;columnInt(0); 
&gt;     if (lastError() != SQLITE_ROW)
&gt;         return false;
&gt; 
&gt; I like that better than having a local variable named error. The code below
&gt; also doesn’t need a local variable.
&gt; 
&gt;     return lastError() == SQLITE_OK;

Your proposal is extending the lifetime of the statement. I was trying to keep the same lifetime as before r277571 (which is why I had added the scope in the first place). Maybe it doesn&apos;t matter though.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1790346</commentid>
    <comment_count>5</comment_count>
      <attachid>437308</attachid>
    <who name="Chris Dumez">cdumez</who>
    <bug_when>2021-09-03 13:52:39 -0700</bug_when>
    <thetext>Created attachment 437308
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1790374</commentid>
    <comment_count>6</comment_count>
      <attachid>437308</attachid>
    <who name="Alex Christensen">achristensen</who>
    <bug_when>2021-09-03 14:43:39 -0700</bug_when>
    <thetext>Comment on attachment 437308
Patch

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

&gt; Source/WebCore/platform/sql/SQLiteDatabase.cpp:625
&gt; +    auto statement = prepareStatement(&quot;PRAGMA auto_vacuum&quot;_s);

I&apos;m not sure if there is a consequence to having this statement call finalize after the statement inside executeCommand or runVacuumCommand, but I think this might change behavior more than we want it to.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1790379</commentid>
    <comment_count>7</comment_count>
      <attachid>437308</attachid>
    <who name="Chris Dumez">cdumez</who>
    <bug_when>2021-09-03 14:46:26 -0700</bug_when>
    <thetext>Comment on attachment 437308
Patch

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

&gt;&gt; Source/WebCore/platform/sql/SQLiteDatabase.cpp:625
&gt;&gt; +    auto statement = prepareStatement(&quot;PRAGMA auto_vacuum&quot;_s);
&gt; 
&gt; I&apos;m not sure if there is a consequence to having this statement call finalize after the statement inside executeCommand or runVacuumCommand, but I think this might change behavior more than we want it to.

I thought about it and I personally don&apos;t see how it changes behavior. Yes, 2 statements will live at the same time but I don&apos;t see any issue with that (except that we&apos;re using a very tiny amount of extra memory for a little bit longer).</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>1790405</commentid>
    <comment_count>8</comment_count>
    <who name="EWS">ews-feeder</who>
    <bug_when>2021-09-03 15:16:08 -0700</bug_when>
    <thetext>Committed r282030 (241334@main): &lt;https://commits.webkit.org/241334@main&gt;

All reviewed patches have been landed. Closing bug and clearing flags on attachment 437308.</thetext>
  </long_desc>
      
          <attachment
              isobsolete="1"
              ispatch="1"
              isprivate="0"
          >
            <attachid>437299</attachid>
            <date>2021-09-03 12:44:32 -0700</date>
            <delta_ts>2021-09-03 13:52:37 -0700</delta_ts>
            <desc>Patch</desc>
            <filename>bug-229886-20210903124431.patch</filename>
            <type>text/plain</type>
            <size>2385</size>
            <attacher name="Chris Dumez">cdumez</attacher>
            
              <data encoding="base64">U3VidmVyc2lvbiBSZXZpc2lvbjogMjgyMDA5CmRpZmYgLS1naXQgYS9Tb3VyY2UvV2ViQ29yZS9D
aGFuZ2VMb2cgYi9Tb3VyY2UvV2ViQ29yZS9DaGFuZ2VMb2cKaW5kZXggMDYxYzA3ZjVkMjgwZWQw
YTdiZmFlYTNhODliYjIyNDlhZDhjYzgwOS4uOTQyZGU0NDg3YzkzNGM1N2MwNzBjOGYyYjM3MGNl
ZDhlZTBiM2YzYSAxMDA2NDQKLS0tIGEvU291cmNlL1dlYkNvcmUvQ2hhbmdlTG9nCisrKyBiL1Nv
dXJjZS9XZWJDb3JlL0NoYW5nZUxvZwpAQCAtMSwzICsxLDIyIEBACisyMDIxLTA5LTAzICBDaHJp
cyBEdW1leiAgPGNkdW1lekBhcHBsZS5jb20+CisKKyAgICAgICAgUmVncmVzc2lvbihyMjc3NTcx
KSBDYWxsIHRvIFNRTGl0ZURhdGFiYXNlOjp0dXJuT25JbmNyZW1lbnRhbEF1dG9WYWN1dW0oKSBm
cm9tIElUUCBmYWlscworICAgICAgICBodHRwczovL2J1Z3Mud2Via2l0Lm9yZy9zaG93X2J1Zy5j
Z2k/aWQ9MjI5ODg2CisgICAgICAgIDxyZGFyOi8vODI1ODE1MDc+CisKKyAgICAgICAgUmV2aWV3
ZWQgYnkgTk9CT0RZIChPT1BTISkuCisKKyAgICAgICAgQmVmb3JlIHIyNzc1NzEsIGBsYXN0RXJy
b3IoKWAgd2FzIGdldHRpbmcgY2FsbGVkIGFmdGVyIHRoZSBjYWxsIHRvIGBzdGF0ZW1lbnQtPmNv
bHVtbkludCgwKWAKKyAgICAgICAgYW5kICpiZWZvcmUqIHRoZSBjYWxsIHRvIGBzdGF0ZW1lbnQu
ZmluYWxpemUoKWAuIEFmdGVyIHIyNzc1NzEsIHRoZSBjYWxsIHRvIGBzdGF0ZW1lbnQuZmluYWxp
emUoKWAKKyAgICAgICAgYmVjYW1lIGltcGxpY2l0LCBhbmQgZ2V0cyBjYWxsZWQgd2hlbiBgc3Rh
dGVtZW50YCBkb2VzIG91dCBvZiBzY29wZS4gQXMgYSByZXN1bHQsIGBsYXN0RXJyb3IoKWAKKyAg
ICAgICAgd2FzIGdldHRpbmcgY2FsbGVkICphZnRlciogdGhlIHN0YXRlbWVudCBmaW5hbGl6YXRp
b24gaW5zdGVhZCBvZiBhZnRlci4gVGhpcyBpcyBhbiBpc3N1ZSBiZWNhdXNlCisgICAgICAgIHRo
ZSBjb2RlIGV4cGVjdHMgdGhlIGxhc3QgZXJyb3IgdG8gYmUgZm9yIGBzdGF0ZW1lbnQtPmNvbHVt
bkludCgwKWAgYW5kIHRodXMgZXhwZWN0cyBTUUxJVEVfUk9XLgorICAgICAgICBJIG1vdmVkIHRo
ZSBgbGFzdEVycm9yKClgIGNhbGwgc28gdGhhdCBpdCBub3cgYWZ0ZXIgYmV0d2VlbiBgc3RhdGVt
ZW50LT5jb2x1bW5JbnQoMClgIGFuZCB0aGUKKyAgICAgICAgaW1wbGljaXQgc3RhdGVtZW50IGZp
bmFsaXphdGlvbiwgbGlrZSBpdCB1c2VkIHRvLgorCisgICAgICAgICogcGxhdGZvcm0vc3FsL1NR
TGl0ZURhdGFiYXNlLmNwcDoKKyAgICAgICAgKFdlYkNvcmU6OlNRTGl0ZURhdGFiYXNlOjp0dXJu
T25JbmNyZW1lbnRhbEF1dG9WYWN1dW0pOgorCiAyMDIxLTA5LTAzICBaaXJhbiBTdW4gIDx6c3Vu
QGlnYWxpYS5jb20+CiAKICAgICAgICAgUkVHUkVTU0lPTihyMjgwMDc4KTogYnJva2UgZmFzdC9p
bWFnZXMvZXhpZi1vcmllbnRhdGlvbi1jb21wb3NpdGVkLmh0bWwgb24gd2luZG93cwpkaWZmIC0t
Z2l0IGEvU291cmNlL1dlYkNvcmUvcGxhdGZvcm0vc3FsL1NRTGl0ZURhdGFiYXNlLmNwcCBiL1Nv
dXJjZS9XZWJDb3JlL3BsYXRmb3JtL3NxbC9TUUxpdGVEYXRhYmFzZS5jcHAKaW5kZXggNzQzZWYz
ZGM4NDExZmU5ZTA5ODNlODA3NTEyNWFjM2JhYTEyNTQ4ZC4uZTA2Zjg5MGU0Y2VlNjRmYjEzZmYy
MGZiNDM1NmNjNDgxMjcyZDY2MiAxMDA2NDQKLS0tIGEvU291cmNlL1dlYkNvcmUvcGxhdGZvcm0v
c3FsL1NRTGl0ZURhdGFiYXNlLmNwcAorKysgYi9Tb3VyY2UvV2ViQ29yZS9wbGF0Zm9ybS9zcWwv
U1FMaXRlRGF0YWJhc2UuY3BwCkBAIC02MjMsOSArNjIzLDExIEBAIGJvb2wgU1FMaXRlRGF0YWJh
c2U6OmlzQXV0b0NvbW1pdE9uKCkgY29uc3QKIGJvb2wgU1FMaXRlRGF0YWJhc2U6OnR1cm5Pbklu
Y3JlbWVudGFsQXV0b1ZhY3V1bSgpCiB7CiAgICAgaW50IGF1dG9WYWN1dW1Nb2RlID0gMDsKLSAg
ICBpZiAoYXV0byBzdGF0ZW1lbnQgPSBwcmVwYXJlU3RhdGVtZW50KCJQUkFHTUEgYXV0b192YWN1
dW0iX3MpKQorICAgIGludCBlcnJvciA9IDA7CisgICAgaWYgKGF1dG8gc3RhdGVtZW50ID0gcHJl
cGFyZVN0YXRlbWVudCgiUFJBR01BIGF1dG9fdmFjdXVtIl9zKSkgewogICAgICAgICBhdXRvVmFj
dXVtTW9kZSA9IHN0YXRlbWVudC0+Y29sdW1uSW50KDApOwotICAgIGludCBlcnJvciA9IGxhc3RF
cnJvcigpOworICAgICAgICBlcnJvciA9IGxhc3RFcnJvcigpOworICAgIH0KIAogICAgIC8vIENo
ZWNrIGlmIHdlIGdvdCBhbiBlcnJvciB3aGlsZSB0cnlpbmcgdG8gZ2V0IHRoZSB2YWx1ZSBvZiB0
aGUgYXV0b192YWN1dW0gZmxhZy4KICAgICAvLyBJZiB3ZSBnb3QgYSBTUUxJVEVfQlVTWSBlcnJv
ciwgdGhlbiB0aGVyZSdzIHByb2JhYmx5IGFub3RoZXIgdHJhbnNhY3Rpb24gaW4K
</data>

          </attachment>
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>437308</attachid>
            <date>2021-09-03 13:52:39 -0700</date>
            <delta_ts>2021-09-03 15:16:09 -0700</delta_ts>
            <desc>Patch</desc>
            <filename>bug-229886-20210903135238.patch</filename>
            <type>text/plain</type>
            <size>3205</size>
            <attacher name="Chris Dumez">cdumez</attacher>
            
              <data encoding="base64">U3VidmVyc2lvbiBSZXZpc2lvbjogMjgyMDIwCmRpZmYgLS1naXQgYS9Tb3VyY2UvV2ViQ29yZS9D
aGFuZ2VMb2cgYi9Tb3VyY2UvV2ViQ29yZS9DaGFuZ2VMb2cKaW5kZXggM2IxNDJjYTY1N2ZhZDFm
YWY5NmVkZTA2MDk3NTY4YzMzZjQ2NjllMy4uNTQ0OWJkYzVmYzRhNzAzMzMyYzMyMzE0MzMxYTgz
MzU2YTI2MmVkMiAxMDA2NDQKLS0tIGEvU291cmNlL1dlYkNvcmUvQ2hhbmdlTG9nCisrKyBiL1Nv
dXJjZS9XZWJDb3JlL0NoYW5nZUxvZwpAQCAtMSwzICsxLDIyIEBACisyMDIxLTA5LTAzICBDaHJp
cyBEdW1leiAgPGNkdW1lekBhcHBsZS5jb20+CisKKyAgICAgICAgUmVncmVzc2lvbihyMjc3NTcx
KSBDYWxsIHRvIFNRTGl0ZURhdGFiYXNlOjp0dXJuT25JbmNyZW1lbnRhbEF1dG9WYWN1dW0oKSBm
cm9tIElUUCBmYWlscworICAgICAgICBodHRwczovL2J1Z3Mud2Via2l0Lm9yZy9zaG93X2J1Zy5j
Z2k/aWQ9MjI5ODg2CisgICAgICAgIDxyZGFyOi8vODI1ODE1MDc+CisKKyAgICAgICAgUmV2aWV3
ZWQgYnkgQWxleCBDaHJpc3RlbnNlbi4KKworICAgICAgICBCZWZvcmUgcjI3NzU3MSwgYGxhc3RF
cnJvcigpYCB3YXMgZ2V0dGluZyBjYWxsZWQgYWZ0ZXIgdGhlIGNhbGwgdG8gYHN0YXRlbWVudC0+
Y29sdW1uSW50KDApYAorICAgICAgICBhbmQgKmJlZm9yZSogdGhlIGNhbGwgdG8gYHN0YXRlbWVu
dC5maW5hbGl6ZSgpYC4gQWZ0ZXIgcjI3NzU3MSwgdGhlIGNhbGwgdG8gYHN0YXRlbWVudC5maW5h
bGl6ZSgpYAorICAgICAgICBiZWNhbWUgaW1wbGljaXQsIGFuZCBnZXRzIGNhbGxlZCB3aGVuIGBz
dGF0ZW1lbnRgIGRvZXMgb3V0IG9mIHNjb3BlLiBBcyBhIHJlc3VsdCwgYGxhc3RFcnJvcigpYAor
ICAgICAgICB3YXMgZ2V0dGluZyBjYWxsZWQgKmFmdGVyKiB0aGUgc3RhdGVtZW50IGZpbmFsaXph
dGlvbiBpbnN0ZWFkIG9mIGFmdGVyLiBUaGlzIGlzIGFuIGlzc3VlIGJlY2F1c2UKKyAgICAgICAg
dGhlIGNvZGUgZXhwZWN0cyB0aGUgbGFzdCBlcnJvciB0byBiZSBmb3IgYHN0YXRlbWVudC0+Y29s
dW1uSW50KDApYCBhbmQgdGh1cyBleHBlY3RzIFNRTElURV9ST1cuCisgICAgICAgIEkgbW92ZWQg
dGhlIGBsYXN0RXJyb3IoKWAgY2FsbCBzbyB0aGF0IGl0IG5vdyBhZnRlciBiZXR3ZWVuIGBzdGF0
ZW1lbnQtPmNvbHVtbkludCgwKWAgYW5kIHRoZQorICAgICAgICBpbXBsaWNpdCBzdGF0ZW1lbnQg
ZmluYWxpemF0aW9uLCBsaWtlIGl0IHVzZWQgdG8uCisKKyAgICAgICAgKiBwbGF0Zm9ybS9zcWwv
U1FMaXRlRGF0YWJhc2UuY3BwOgorICAgICAgICAoV2ViQ29yZTo6U1FMaXRlRGF0YWJhc2U6OnR1
cm5PbkluY3JlbWVudGFsQXV0b1ZhY3V1bSk6CisKIDIwMjEtMDktMDMgIEFkaXR5YSBLZWVydGhp
ICA8YWtlZXJ0aGlAYXBwbGUuY29tPgogCiAgICAgICAgIGlmcmFtZXMgc2hvdWxkIGdldCBhbiBv
cGFxdWUgYmFja2dyb3VuZCB3aGVuIHRoZSBlbWJlZGRpbmcgZWxlbWVudCBhbmQgZW1iZWRkZWQg
cm9vdCBjb2xvci1zY2hlbWVzIGRvIG5vdCBtYXRjaApkaWZmIC0tZ2l0IGEvU291cmNlL1dlYkNv
cmUvcGxhdGZvcm0vc3FsL1NRTGl0ZURhdGFiYXNlLmNwcCBiL1NvdXJjZS9XZWJDb3JlL3BsYXRm
b3JtL3NxbC9TUUxpdGVEYXRhYmFzZS5jcHAKaW5kZXggNzQzZWYzZGM4NDExZmU5ZTA5ODNlODA3
NTEyNWFjM2JhYTEyNTQ4ZC4uMTg0MzgzOTk3ZDU1ZDRjNTZjMmIxOTIyNDFlNjkxNDY1MGU0ZTA4
MyAxMDA2NDQKLS0tIGEvU291cmNlL1dlYkNvcmUvcGxhdGZvcm0vc3FsL1NRTGl0ZURhdGFiYXNl
LmNwcAorKysgYi9Tb3VyY2UvV2ViQ29yZS9wbGF0Zm9ybS9zcWwvU1FMaXRlRGF0YWJhc2UuY3Bw
CkBAIC02MjIsMTAgKzYyMiwxMSBAQCBib29sIFNRTGl0ZURhdGFiYXNlOjppc0F1dG9Db21taXRP
bigpIGNvbnN0CiAKIGJvb2wgU1FMaXRlRGF0YWJhc2U6OnR1cm5PbkluY3JlbWVudGFsQXV0b1Zh
Y3V1bSgpCiB7Ci0gICAgaW50IGF1dG9WYWN1dW1Nb2RlID0gMDsKLSAgICBpZiAoYXV0byBzdGF0
ZW1lbnQgPSBwcmVwYXJlU3RhdGVtZW50KCJQUkFHTUEgYXV0b192YWN1dW0iX3MpKQotICAgICAg
ICBhdXRvVmFjdXVtTW9kZSA9IHN0YXRlbWVudC0+Y29sdW1uSW50KDApOwotICAgIGludCBlcnJv
ciA9IGxhc3RFcnJvcigpOworICAgIGF1dG8gc3RhdGVtZW50ID0gcHJlcGFyZVN0YXRlbWVudCgi
UFJBR01BIGF1dG9fdmFjdXVtIl9zKTsKKyAgICBpZiAoIXN0YXRlbWVudCkKKyAgICAgICAgcmV0
dXJuIGZhbHNlOworCisgICAgaW50IGF1dG9WYWN1dW1Nb2RlID0gc3RhdGVtZW50LT5jb2x1bW5J
bnQoMCk7CiAKICAgICAvLyBDaGVjayBpZiB3ZSBnb3QgYW4gZXJyb3Igd2hpbGUgdHJ5aW5nIHRv
IGdldCB0aGUgdmFsdWUgb2YgdGhlIGF1dG9fdmFjdXVtIGZsYWcuCiAgICAgLy8gSWYgd2UgZ290
IGEgU1FMSVRFX0JVU1kgZXJyb3IsIHRoZW4gdGhlcmUncyBwcm9iYWJseSBhbm90aGVyIHRyYW5z
YWN0aW9uIGluCkBAIC02MzMsNyArNjM0LDcgQEAgYm9vbCBTUUxpdGVEYXRhYmFzZTo6dHVybk9u
SW5jcmVtZW50YWxBdXRvVmFjdXVtKCkKICAgICAvLyBhdXRvX3ZhY3V1bSBmbGFnIGFuZCB0cnkg
dG8gc2V0IGl0IHRvIElOQ1JFTUVOVEFMIHRoZSBuZXh0IHRpbWUgd2Ugb3BlbiB0aGlzCiAgICAg
Ly8gZGF0YWJhc2UuIElmIHRoZSBlcnJvciBpcyBub3QgU1FMSVRFX0JVU1ksIHRoZW4gd2UgcHJv
YmFibHkgcmFuIGludG8gYSBtb3JlCiAgICAgLy8gc2VyaW91cyBwcm9ibGVtIGFuZCBzaG91bGQg
cmV0dXJuIGZhbHNlICh0byBsb2cgYW4gZXJyb3IgbWVzc2FnZSkuCi0gICAgaWYgKGVycm9yICE9
IFNRTElURV9ST1cpCisgICAgaWYgKGxhc3RFcnJvcigpICE9IFNRTElURV9ST1cpCiAgICAgICAg
IHJldHVybiBmYWxzZTsKIAogICAgIHN3aXRjaCAoYXV0b1ZhY3V1bU1vZGUpIHsKQEAgLTY0Niw4
ICs2NDcsNyBAQCBib29sIFNRTGl0ZURhdGFiYXNlOjp0dXJuT25JbmNyZW1lbnRhbEF1dG9WYWN1
dW0oKQogICAgICAgICBpZiAoIWV4ZWN1dGVDb21tYW5kKCJQUkFHTUEgYXV0b192YWN1dW0gPSAy
Il9zKSkKICAgICAgICAgICAgIHJldHVybiBmYWxzZTsKICAgICAgICAgcnVuVmFjdXVtQ29tbWFu
ZCgpOwotICAgICAgICBlcnJvciA9IGxhc3RFcnJvcigpOwotICAgICAgICByZXR1cm4gKGVycm9y
ID09IFNRTElURV9PSyk7CisgICAgICAgIHJldHVybiBsYXN0RXJyb3IoKSA9PSBTUUxJVEVfT0s7
CiAgICAgfQogfQogCg==
</data>

          </attachment>
      

    </bug>

</bugzilla>