<?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>41477</bug_id>
          
          <creation_ts>2010-07-01 11:57:56 -0700</creation_ts>
          <short_desc>Direct calls to cast operator in WebFrameImpl.cpp</short_desc>
          <delta_ts>2010-07-08 01:49:20 -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>Forms</component>
          <version>528+ (Nightly build)</version>
          <rep_platform>All</rep_platform>
          <op_sys>All</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>
          <dependson>41499</dependson>
          
          <everconfirmed>1</everconfirmed>
          <reporter name="David Holloway">dhollowa</reporter>
          <assigned_to name="David Holloway">dhollowa</assigned_to>
          <cc>abarth</cc>
    
    <cc>commit-queue</cc>
    
    <cc>dhollowa</cc>
    
    <cc>eric</cc>
    
    <cc>fishd</cc>
    
    <cc>levin</cc>
    
    <cc>webkit.review.bot</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>245459</commentid>
    <comment_count>0</comment_count>
    <who name="David Holloway">dhollowa</who>
    <bug_when>2010-07-01 11:57:56 -0700</bug_when>
    <thetext>Overview: Poor C++ style with direct calls to cast operator in WebFrameImpl.cpp.

Steps to Reproduce:

1) Open WebFrameImpl.cpp

2) Inspect WebKit::WebFrameImpl::registerPasswordListener and WebKit::WebFrameImpl::notifiyPasswordListenerOfAutocomplete

Actual Results: Notice the calls to:

   RefPtr&lt;HTMLInputElement&gt; element = inputElement.operator PassRefPtr&lt;HTMLInputElement&gt;();

   This is using an explicit call to a PassRefPtr cast operator to bridge from a WebInputElement back to an HTMLInputElement.

Expected Results:  Better style is to &quot;unwrap&quot; the WebInputElement explicitly, eg.:

   RefPtr&lt;HTMLInputElement&gt; element(inputElement.unwrap&lt;HTMLInputElement&gt;());</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>245483</commentid>
    <comment_count>1</comment_count>
    <who name="David Holloway">dhollowa</who>
    <bug_when>2010-07-01 12:31:43 -0700</bug_when>
    <thetext>Follow up for bug 41236.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>245485</commentid>
    <comment_count>2</comment_count>
      <attachid>60272</attachid>
    <who name="David Holloway">dhollowa</who>
    <bug_when>2010-07-01 12:34:15 -0700</bug_when>
    <thetext>Created attachment 60272
Proposed patch.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>245509</commentid>
    <comment_count>3</comment_count>
      <attachid>60277</attachid>
    <who name="David Holloway">dhollowa</who>
    <bug_when>2010-07-01 13:09:17 -0700</bug_when>
    <thetext>Created attachment 60277
Proposed patch.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>245512</commentid>
    <comment_count>4</comment_count>
      <attachid>60277</attachid>
    <who name="Darin Fisher (:fishd, Google)">fishd</who>
    <bug_when>2010-07-01 13:18:13 -0700</bug_when>
    <thetext>Comment on attachment 60277
Proposed patch.

Thanks!  R=me</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>245711</commentid>
    <comment_count>5</comment_count>
      <attachid>60277</attachid>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2010-07-01 19:50:48 -0700</bug_when>
    <thetext>Comment on attachment 60277
Proposed patch.

Clearing flags on attachment: 60277

Committed r62349: &lt;http://trac.webkit.org/changeset/62349&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>245712</commentid>
    <comment_count>6</comment_count>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2010-07-01 19:50:52 -0700</bug_when>
    <thetext>All reviewed patches have been landed.  Closing bug.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>245716</commentid>
    <comment_count>7</comment_count>
    <who name="WebKit Review Bot">webkit.review.bot</who>
    <bug_when>2010-07-01 20:00:37 -0700</bug_when>
    <thetext>http://trac.webkit.org/changeset/62349 might have broken Chromium Linux Release</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>245727</commentid>
    <comment_count>8</comment_count>
    <who name="David Levin">levin</who>
    <bug_when>2010-07-01 20:15:11 -0700</bug_when>
    <thetext>Rolled out due to breakage on Linux.

http://trac.webkit.org/changeset/62351</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>245730</commentid>
    <comment_count>9</comment_count>
    <who name="David Levin">levin</who>
    <bug_when>2010-07-01 20:17:45 -0700</bug_when>
    <thetext>And OSX bustage. Here&apos;s the compile error:


/Users/cltbld/Desktop/BuildSlaveData/WebKit-BuildSlave/chromium-mac-release/build/WebKit/chromium/src/WebFrameImpl.cpp: In member function â€˜virtual void WebKit::WebFrameImpl::notifiyPasswordListenerOfAutocomplete(const WebKit::WebInputElement&amp;)â€™:
/Users/cltbld/Desktop/BuildSlaveData/WebKit-BuildSlave/chromium-mac-release/build/WebKit/chromium/src/WebFrameImpl.cpp:1974: error: passing â€˜const WebKit::WebInputElementâ€™ as â€˜thisâ€™ argument of â€˜T* WebKit::WebNode::unwrap() [with T = WebCore::HTMLInputElement]â€™ discards qualifiers</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>247812</commentid>
    <comment_count>10</comment_count>
      <attachid>60792</attachid>
    <who name="David Holloway">dhollowa</who>
    <bug_when>2010-07-07 15:46:47 -0700</bug_when>
    <thetext>Created attachment 60792
Proposed patch.  Fixes const-ness issues.

Grrrr.  False positive my end.  New patch addresses const-ness issues and pushes the const-ness of the |inputElement| parameter down a level to WebFrameImpl::getPasswordListener().  We need a const_cast at this level due to the use of non-const RefPtr&lt;HTMLInputElement&gt; used as the key to the |m_passwordListeners| map.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>248088</commentid>
    <comment_count>11</comment_count>
      <attachid>60792</attachid>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2010-07-08 01:49:15 -0700</bug_when>
    <thetext>Comment on attachment 60792
Proposed patch.  Fixes const-ness issues.

Clearing flags on attachment: 60792

Committed r62770: &lt;http://trac.webkit.org/changeset/62770&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>248089</commentid>
    <comment_count>12</comment_count>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2010-07-08 01:49:20 -0700</bug_when>
    <thetext>All reviewed patches have been landed.  Closing bug.</thetext>
  </long_desc>
      
          <attachment
              isobsolete="1"
              ispatch="1"
              isprivate="0"
          >
            <attachid>60272</attachid>
            <date>2010-07-01 12:34:15 -0700</date>
            <delta_ts>2010-07-01 13:09:17 -0700</delta_ts>
            <desc>Proposed patch.</desc>
            <filename>proposed_patch.diff</filename>
            <type>text/plain</type>
            <size>2658</size>
            <attacher name="David Holloway">dhollowa</attacher>
            
              <data encoding="base64">SW5kZXg6IFdlYktpdC9jaHJvbWl1bS9DaGFuZ2VMb2cKPT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQotLS0gV2ViS2l0L2No
cm9taXVtL0NoYW5nZUxvZwkocmV2aXNpb24gNjIyNzYpCisrKyBXZWJLaXQvY2hyb21pdW0vQ2hh
bmdlTG9nCSh3b3JraW5nIGNvcHkpCkBAIC0xLDMgKzEsMTkgQEAKKzIwMTAtMDctMDEgIERhdmlk
IEhvbGxvd2F5ICA8ZGhvbGxvd2FAY2hyb21pdW0ub3JnPgorCisgICAgICAgIFJldmlld2VkIGJ5
IE5PQk9EWSAoT09QUyEpLgorCisgICAgICAgIFtjaHJvbWl1bV0gRXhwb3NlcyBXZWJOb2RlOjp1
bndyYXAoKSBhbmQgV2ViTm9kZTo6Y29uc3RVbndyYXAoKSBmb3IgdXNlIGJ5IG90aGVyIGNvZGUg
aW4gV2ViS2l0L2Nocm9taXVtL3NyYy4KKworICAgICAgICBTcGVjaWZpYyB1c2Ugb2YgdGhlc2Ug
bWV0aG9kcyBpcyBtYWRlIGluIFdlYkZyYW1lSW1wbC5jcHAuICBUaGlzIGlzIHByZWZlcnJlZCB0
byB0aGUgY2FzdCBvcGVyYXRvciBjYWxsIHRoYXQKKyAgICAgICAgd2FzIGhhcHBlbmluZyBwcmlv
ciB0byB0aGlzIGNoYW5nZS4KKworICAgICAgICBodHRwczovL2J1Z3Mud2Via2l0Lm9yZy9zaG93
X2J1Zy5jZ2k/aWQ9NDE0NzcKKworICAgICAgICAqIHB1YmxpYy9XZWJOb2RlLmg6CisgICAgICAg
ICogc3JjL1dlYkZyYW1lSW1wbC5jcHA6CisgICAgICAgIChXZWJLaXQ6OldlYkZyYW1lSW1wbDo6
cmVnaXN0ZXJQYXNzd29yZExpc3RlbmVyKToKKyAgICAgICAgKFdlYktpdDo6V2ViRnJhbWVJbXBs
Ojpub3RpZml5UGFzc3dvcmRMaXN0ZW5lck9mQXV0b2NvbXBsZXRlKToKKwogMjAxMC0wNy0wMSAg
U2hlcmlmZiBCb3QgIDx3ZWJraXQucmV2aWV3LmJvdEBnbWFpbC5jb20+CiAKICAgICAgICAgVW5y
ZXZpZXdlZCwgcm9sbGluZyBvdXQgcjYyMjQ2LgpJbmRleDogV2ViS2l0L2Nocm9taXVtL3B1Ymxp
Yy9XZWJOb2RlLmgKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PQotLS0gV2ViS2l0L2Nocm9taXVtL3B1YmxpYy9XZWJOb2Rl
LmgJKHJldmlzaW9uIDYyMjc1KQorKysgV2ViS2l0L2Nocm9taXVtL3B1YmxpYy9XZWJOb2RlLmgJ
KHdvcmtpbmcgY29weSkKQEAgLTEyNCw3ICsxMjQsNiBAQCBwdWJsaWM6CiAgICAgb3BlcmF0b3Ig
V1RGOjpQYXNzUmVmUHRyPFdlYkNvcmU6Ok5vZGU+KCkgY29uc3Q7CiAjZW5kaWYKIAotcHJvdGVj
dGVkOgogI2lmIFdFQktJVF9JTVBMRU1FTlRBVElPTgogICAgIHRlbXBsYXRlPHR5cGVuYW1lIFQ+
IFQqIHVud3JhcCgpCiAgICAgewpAQCAtMTM3LDYgKzEzNiw3IEBAIHByb3RlY3RlZDoKICAgICB9
CiAjZW5kaWYKIAorcHJvdGVjdGVkOgogICAgIFdlYlByaXZhdGVQdHI8V2ViQ29yZTo6Tm9kZT4g
bV9wcml2YXRlOwogfTsKIApJbmRleDogV2ViS2l0L2Nocm9taXVtL3NyYy9XZWJGcmFtZUltcGwu
Y3BwCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT0KLS0tIFdlYktpdC9jaHJvbWl1bS9zcmMvV2ViRnJhbWVJbXBsLmNwcAko
cmV2aXNpb24gNjIyNzUpCisrKyBXZWJLaXQvY2hyb21pdW0vc3JjL1dlYkZyYW1lSW1wbC5jcHAJ
KHdvcmtpbmcgY29weSkKQEAgLTE5NjAsNyArMTk2MCw3IEBAIGJvb2wgV2ViRnJhbWVJbXBsOjpy
ZWdpc3RlclBhc3N3b3JkTGlzdGUKICAgICBXZWJJbnB1dEVsZW1lbnQgaW5wdXRFbGVtZW50LAog
ICAgIFdlYlBhc3N3b3JkQXV0b2NvbXBsZXRlTGlzdGVuZXIqIGxpc3RlbmVyKQogewotICAgIFJl
ZlB0cjxIVE1MSW5wdXRFbGVtZW50PiBlbGVtZW50ID0gaW5wdXRFbGVtZW50Lm9wZXJhdG9yIFBh
c3NSZWZQdHI8SFRNTElucHV0RWxlbWVudD4oKTsKKyAgICBSZWZQdHI8SFRNTElucHV0RWxlbWVu
dD4gZWxlbWVudChpbnB1dEVsZW1lbnQudW53cmFwPEhUTUxJbnB1dEVsZW1lbnQ+KCkpOwogICAg
IGlmICghbV9wYXNzd29yZExpc3RlbmVycy5hZGQoZWxlbWVudCwgbGlzdGVuZXIpLnNlY29uZCkg
ewogICAgICAgICBkZWxldGUgbGlzdGVuZXI7CiAgICAgICAgIHJldHVybiBmYWxzZTsKQEAgLTE5
NzEsNyArMTk3MSw3IEBAIGJvb2wgV2ViRnJhbWVJbXBsOjpyZWdpc3RlclBhc3N3b3JkTGlzdGUK
IHZvaWQgV2ViRnJhbWVJbXBsOjpub3RpZml5UGFzc3dvcmRMaXN0ZW5lck9mQXV0b2NvbXBsZXRl
KAogICAgIGNvbnN0IFdlYklucHV0RWxlbWVudCYgaW5wdXRFbGVtZW50KQogewotICAgIFJlZlB0
cjxIVE1MSW5wdXRFbGVtZW50PiBlbGVtZW50ID0gaW5wdXRFbGVtZW50Lm9wZXJhdG9yIFBhc3NS
ZWZQdHI8SFRNTElucHV0RWxlbWVudD4oKTsKKyAgICBSZWZQdHI8SFRNTElucHV0RWxlbWVudD4g
ZWxlbWVudChpbnB1dEVsZW1lbnQudW53cmFwPEhUTUxJbnB1dEVsZW1lbnQ+KCkpOwogICAgIFdl
YlBhc3N3b3JkQXV0b2NvbXBsZXRlTGlzdGVuZXIqIGxpc3RlbmVyID0gZ2V0UGFzc3dvcmRMaXN0
ZW5lcihlbGVtZW50LmdldCgpKTsKICAgICAvLyBQYXNzd29yZCBsaXN0ZW5lcnMgbmVlZCB0byBh
dXRvY29tcGxldGUgb3RoZXIgZmllbGRzIHRoYXQgZGVwZW5kIG9uIHRoZQogICAgIC8vIGlucHV0
IGVsZW1lbnQgd2l0aCBhdXRvZmlsbCBzdWdnZXN0aW9ucy4K
</data>

          </attachment>
          <attachment
              isobsolete="1"
              ispatch="1"
              isprivate="0"
          >
            <attachid>60277</attachid>
            <date>2010-07-01 13:09:17 -0700</date>
            <delta_ts>2010-07-07 15:46:47 -0700</delta_ts>
            <desc>Proposed patch.</desc>
            <filename>proposed_patch.diff</filename>
            <type>text/plain</type>
            <size>2677</size>
            <attacher name="David Holloway">dhollowa</attacher>
            
              <data encoding="base64">SW5kZXg6IFdlYktpdC9jaHJvbWl1bS9DaGFuZ2VMb2cKPT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQotLS0gV2ViS2l0L2No
cm9taXVtL0NoYW5nZUxvZwkocmV2aXNpb24gNjIyNzYpCisrKyBXZWJLaXQvY2hyb21pdW0vQ2hh
bmdlTG9nCSh3b3JraW5nIGNvcHkpCkBAIC0xLDMgKzEsMjEgQEAKKzIwMTAtMDctMDEgIERhdmlk
IEhvbGxvd2F5ICA8ZGhvbGxvd2FAY2hyb21pdW0ub3JnPgorCisgICAgICAgIFJldmlld2VkIGJ5
IE5PQk9EWSAoT09QUyEpLgorCisgICAgICAgIFtjaHJvbWl1bV0gRXhwb3NlcyBXZWJOb2RlOjp1
bndyYXAoKSBhbmQgV2ViTm9kZTo6Y29uc3RVbndyYXAoKSBmb3IgCisgICAgICAgIHVzZSBieSBv
dGhlciBjb2RlIGluIFdlYktpdC9jaHJvbWl1bS9zcmMuCisKKyAgICAgICAgU3BlY2lmaWMgdXNl
IG9mIHRoZXNlIG1ldGhvZHMgaXMgbWFkZSBpbiBXZWJGcmFtZUltcGwuY3BwLiAgVGhpcyBpcwor
ICAgICAgICBwcmVmZXJyZWQgdG8gdGhlIGNhc3Qgb3BlcmF0b3IgY2FsbCB0aGF0IHdhcyBoYXBw
ZW5pbmcgcHJpb3IgdG8gdGhpcworICAgICAgICBjaGFuZ2UuCisKKyAgICAgICAgaHR0cHM6Ly9i
dWdzLndlYmtpdC5vcmcvc2hvd19idWcuY2dpP2lkPTQxNDc3CisKKyAgICAgICAgKiBwdWJsaWMv
V2ViTm9kZS5oOgorICAgICAgICAqIHNyYy9XZWJGcmFtZUltcGwuY3BwOgorICAgICAgICAoV2Vi
S2l0OjpXZWJGcmFtZUltcGw6OnJlZ2lzdGVyUGFzc3dvcmRMaXN0ZW5lcik6CisgICAgICAgIChX
ZWJLaXQ6OldlYkZyYW1lSW1wbDo6bm90aWZpeVBhc3N3b3JkTGlzdGVuZXJPZkF1dG9jb21wbGV0
ZSk6CisKIDIwMTAtMDctMDEgIFNoZXJpZmYgQm90ICA8d2Via2l0LnJldmlldy5ib3RAZ21haWwu
Y29tPgogCiAgICAgICAgIFVucmV2aWV3ZWQsIHJvbGxpbmcgb3V0IHI2MjI0Ni4KSW5kZXg6IFdl
YktpdC9jaHJvbWl1bS9wdWJsaWMvV2ViTm9kZS5oCj09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT0KLS0tIFdlYktpdC9jaHJv
bWl1bS9wdWJsaWMvV2ViTm9kZS5oCShyZXZpc2lvbiA2MjI3NSkKKysrIFdlYktpdC9jaHJvbWl1
bS9wdWJsaWMvV2ViTm9kZS5oCSh3b3JraW5nIGNvcHkpCkBAIC0xMjQsNyArMTI0LDYgQEAgcHVi
bGljOgogICAgIG9wZXJhdG9yIFdURjo6UGFzc1JlZlB0cjxXZWJDb3JlOjpOb2RlPigpIGNvbnN0
OwogI2VuZGlmCiAKLXByb3RlY3RlZDoKICNpZiBXRUJLSVRfSU1QTEVNRU5UQVRJT04KICAgICB0
ZW1wbGF0ZTx0eXBlbmFtZSBUPiBUKiB1bndyYXAoKQogICAgIHsKQEAgLTEzNyw2ICsxMzYsNyBA
QCBwcm90ZWN0ZWQ6CiAgICAgfQogI2VuZGlmCiAKK3Byb3RlY3RlZDoKICAgICBXZWJQcml2YXRl
UHRyPFdlYkNvcmU6Ok5vZGU+IG1fcHJpdmF0ZTsKIH07CiAKSW5kZXg6IFdlYktpdC9jaHJvbWl1
bS9zcmMvV2ViRnJhbWVJbXBsLmNwcAo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tLSBXZWJLaXQvY2hyb21pdW0vc3Jj
L1dlYkZyYW1lSW1wbC5jcHAJKHJldmlzaW9uIDYyMjc1KQorKysgV2ViS2l0L2Nocm9taXVtL3Ny
Yy9XZWJGcmFtZUltcGwuY3BwCSh3b3JraW5nIGNvcHkpCkBAIC0xOTYwLDcgKzE5NjAsNyBAQCBi
b29sIFdlYkZyYW1lSW1wbDo6cmVnaXN0ZXJQYXNzd29yZExpc3RlCiAgICAgV2ViSW5wdXRFbGVt
ZW50IGlucHV0RWxlbWVudCwKICAgICBXZWJQYXNzd29yZEF1dG9jb21wbGV0ZUxpc3RlbmVyKiBs
aXN0ZW5lcikKIHsKLSAgICBSZWZQdHI8SFRNTElucHV0RWxlbWVudD4gZWxlbWVudCA9IGlucHV0
RWxlbWVudC5vcGVyYXRvciBQYXNzUmVmUHRyPEhUTUxJbnB1dEVsZW1lbnQ+KCk7CisgICAgUmVm
UHRyPEhUTUxJbnB1dEVsZW1lbnQ+IGVsZW1lbnQoaW5wdXRFbGVtZW50LnVud3JhcDxIVE1MSW5w
dXRFbGVtZW50PigpKTsKICAgICBpZiAoIW1fcGFzc3dvcmRMaXN0ZW5lcnMuYWRkKGVsZW1lbnQs
IGxpc3RlbmVyKS5zZWNvbmQpIHsKICAgICAgICAgZGVsZXRlIGxpc3RlbmVyOwogICAgICAgICBy
ZXR1cm4gZmFsc2U7CkBAIC0xOTcxLDcgKzE5NzEsNyBAQCBib29sIFdlYkZyYW1lSW1wbDo6cmVn
aXN0ZXJQYXNzd29yZExpc3RlCiB2b2lkIFdlYkZyYW1lSW1wbDo6bm90aWZpeVBhc3N3b3JkTGlz
dGVuZXJPZkF1dG9jb21wbGV0ZSgKICAgICBjb25zdCBXZWJJbnB1dEVsZW1lbnQmIGlucHV0RWxl
bWVudCkKIHsKLSAgICBSZWZQdHI8SFRNTElucHV0RWxlbWVudD4gZWxlbWVudCA9IGlucHV0RWxl
bWVudC5vcGVyYXRvciBQYXNzUmVmUHRyPEhUTUxJbnB1dEVsZW1lbnQ+KCk7CisgICAgUmVmUHRy
PEhUTUxJbnB1dEVsZW1lbnQ+IGVsZW1lbnQoaW5wdXRFbGVtZW50LnVud3JhcDxIVE1MSW5wdXRF
bGVtZW50PigpKTsKICAgICBXZWJQYXNzd29yZEF1dG9jb21wbGV0ZUxpc3RlbmVyKiBsaXN0ZW5l
ciA9IGdldFBhc3N3b3JkTGlzdGVuZXIoZWxlbWVudC5nZXQoKSk7CiAgICAgLy8gUGFzc3dvcmQg
bGlzdGVuZXJzIG5lZWQgdG8gYXV0b2NvbXBsZXRlIG90aGVyIGZpZWxkcyB0aGF0IGRlcGVuZCBv
biB0aGUKICAgICAvLyBpbnB1dCBlbGVtZW50IHdpdGggYXV0b2ZpbGwgc3VnZ2VzdGlvbnMuCg==
</data>

          </attachment>
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>60792</attachid>
            <date>2010-07-07 15:46:47 -0700</date>
            <delta_ts>2010-07-08 01:49:15 -0700</delta_ts>
            <desc>Proposed patch.  Fixes const-ness issues.</desc>
            <filename>proposed_patch.diff</filename>
            <type>text/plain</type>
            <size>4110</size>
            <attacher name="David Holloway">dhollowa</attacher>
            
              <data encoding="base64">SW5kZXg6IFdlYktpdC9jaHJvbWl1bS9DaGFuZ2VMb2cKPT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PQotLS0gV2ViS2l0L2No
cm9taXVtL0NoYW5nZUxvZwkocmV2aXNpb24gNjI3MTEpCisrKyBXZWJLaXQvY2hyb21pdW0vQ2hh
bmdlTG9nCSh3b3JraW5nIGNvcHkpCkBAIC0xLDMgKzEsMjMgQEAKKzIwMTAtMDctMDcgIERhdmlk
IEhvbGxvd2F5ICA8ZGhvbGxvd2FAY2hyb21pdW0ub3JnPgorCisgICAgICAgIFJldmlld2VkIGJ5
IE5PQk9EWSAoT09QUyEpLgorCisgICAgICAgIFtjaHJvbWl1bV0gRXhwb3NlcyBXZWJOb2RlOjp1
bndyYXAoKSBhbmQgV2ViTm9kZTo6Y29uc3RVbndyYXAoKSBmb3IgCisgICAgICAgIHVzZSBieSBv
dGhlciBjb2RlIGluIFdlYktpdC9jaHJvbWl1bS9zcmMuCisKKyAgICAgICAgU3BlY2lmaWMgdXNl
IG9mIHRoZXNlIG1ldGhvZHMgaXMgbWFkZSBpbiBXZWJGcmFtZUltcGwuY3BwLiAgVGhpcyBpcwor
ICAgICAgICBwcmVmZXJyZWQgdG8gdGhlIGNhc3Qgb3BlcmF0b3IgY2FsbCB0aGF0IHdhcyBoYXBw
ZW5pbmcgcHJpb3IgdG8gdGhpcworICAgICAgICBjaGFuZ2UuCisKKyAgICAgICAgaHR0cHM6Ly9i
dWdzLndlYmtpdC5vcmcvc2hvd19idWcuY2dpP2lkPTQxNDc3CisKKyAgICAgICAgKiBwdWJsaWMv
V2ViTm9kZS5oOgorICAgICAgICAqIHNyYy9XZWJGcmFtZUltcGwuY3BwOgorICAgICAgICAoV2Vi
S2l0OjpXZWJGcmFtZUltcGw6OnJlZ2lzdGVyUGFzc3dvcmRMaXN0ZW5lcik6CisgICAgICAgIChX
ZWJLaXQ6OldlYkZyYW1lSW1wbDo6bm90aWZpeVBhc3N3b3JkTGlzdGVuZXJPZkF1dG9jb21wbGV0
ZSk6CisgICAgICAgIChXZWJLaXQ6OldlYkZyYW1lSW1wbDo6Z2V0UGFzc3dvcmRMaXN0ZW5lcik6
CisgICAgICAgICogc3JjL1dlYkZyYW1lSW1wbC5oOgorCiAyMDEwLTA3LTA3ICBKYW1lcyBIYXdr
aW5zICA8amhhd2tpbnNAY2hyb21pdW0ub3JnPgogCiAgICAgICAgIFJldmlld2VkIGJ5IERpbWl0
cmkgR2xhemtvdi4KSW5kZXg6IFdlYktpdC9jaHJvbWl1bS9wdWJsaWMvV2ViTm9kZS5oCj09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT0KLS0tIFdlYktpdC9jaHJvbWl1bS9wdWJsaWMvV2ViTm9kZS5oCShyZXZpc2lvbiA2Mjcw
NSkKKysrIFdlYktpdC9jaHJvbWl1bS9wdWJsaWMvV2ViTm9kZS5oCSh3b3JraW5nIGNvcHkpCkBA
IC0xMjQsNyArMTI0LDYgQEAgcHVibGljOgogICAgIG9wZXJhdG9yIFdURjo6UGFzc1JlZlB0cjxX
ZWJDb3JlOjpOb2RlPigpIGNvbnN0OwogI2VuZGlmCiAKLXByb3RlY3RlZDoKICNpZiBXRUJLSVRf
SU1QTEVNRU5UQVRJT04KICAgICB0ZW1wbGF0ZTx0eXBlbmFtZSBUPiBUKiB1bndyYXAoKQogICAg
IHsKQEAgLTEzNyw2ICsxMzYsNyBAQCBwcm90ZWN0ZWQ6CiAgICAgfQogI2VuZGlmCiAKK3Byb3Rl
Y3RlZDoKICAgICBXZWJQcml2YXRlUHRyPFdlYkNvcmU6Ok5vZGU+IG1fcHJpdmF0ZTsKIH07CiAK
SW5kZXg6IFdlYktpdC9jaHJvbWl1bS9zcmMvV2ViRnJhbWVJbXBsLmNwcAo9PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0t
LSBXZWJLaXQvY2hyb21pdW0vc3JjL1dlYkZyYW1lSW1wbC5jcHAJKHJldmlzaW9uIDYyNzA1KQor
KysgV2ViS2l0L2Nocm9taXVtL3NyYy9XZWJGcmFtZUltcGwuY3BwCSh3b3JraW5nIGNvcHkpCkBA
IC0xOTYwLDcgKzE5NjAsNyBAQCBib29sIFdlYkZyYW1lSW1wbDo6cmVnaXN0ZXJQYXNzd29yZExp
c3RlCiAgICAgV2ViSW5wdXRFbGVtZW50IGlucHV0RWxlbWVudCwKICAgICBXZWJQYXNzd29yZEF1
dG9jb21wbGV0ZUxpc3RlbmVyKiBsaXN0ZW5lcikKIHsKLSAgICBSZWZQdHI8SFRNTElucHV0RWxl
bWVudD4gZWxlbWVudCA9IGlucHV0RWxlbWVudC5vcGVyYXRvciBQYXNzUmVmUHRyPEhUTUxJbnB1
dEVsZW1lbnQ+KCk7CisgICAgUmVmUHRyPEhUTUxJbnB1dEVsZW1lbnQ+IGVsZW1lbnQoaW5wdXRF
bGVtZW50LnVud3JhcDxIVE1MSW5wdXRFbGVtZW50PigpKTsKICAgICBpZiAoIW1fcGFzc3dvcmRM
aXN0ZW5lcnMuYWRkKGVsZW1lbnQsIGxpc3RlbmVyKS5zZWNvbmQpIHsKICAgICAgICAgZGVsZXRl
IGxpc3RlbmVyOwogICAgICAgICByZXR1cm4gZmFsc2U7CkBAIC0xOTcxLDggKzE5NzEsOCBAQCBi
b29sIFdlYkZyYW1lSW1wbDo6cmVnaXN0ZXJQYXNzd29yZExpc3RlCiB2b2lkIFdlYkZyYW1lSW1w
bDo6bm90aWZpeVBhc3N3b3JkTGlzdGVuZXJPZkF1dG9jb21wbGV0ZSgKICAgICBjb25zdCBXZWJJ
bnB1dEVsZW1lbnQmIGlucHV0RWxlbWVudCkKIHsKLSAgICBSZWZQdHI8SFRNTElucHV0RWxlbWVu
dD4gZWxlbWVudCA9IGlucHV0RWxlbWVudC5vcGVyYXRvciBQYXNzUmVmUHRyPEhUTUxJbnB1dEVs
ZW1lbnQ+KCk7Ci0gICAgV2ViUGFzc3dvcmRBdXRvY29tcGxldGVMaXN0ZW5lciogbGlzdGVuZXIg
PSBnZXRQYXNzd29yZExpc3RlbmVyKGVsZW1lbnQuZ2V0KCkpOworICAgIGNvbnN0IEhUTUxJbnB1
dEVsZW1lbnQqIGVsZW1lbnQgPSBpbnB1dEVsZW1lbnQuY29uc3RVbndyYXA8SFRNTElucHV0RWxl
bWVudD4oKTsKKyAgICBXZWJQYXNzd29yZEF1dG9jb21wbGV0ZUxpc3RlbmVyKiBsaXN0ZW5lciA9
IGdldFBhc3N3b3JkTGlzdGVuZXIoZWxlbWVudCk7CiAgICAgLy8gUGFzc3dvcmQgbGlzdGVuZXJz
IG5lZWQgdG8gYXV0b2NvbXBsZXRlIG90aGVyIGZpZWxkcyB0aGF0IGRlcGVuZCBvbiB0aGUKICAg
ICAvLyBpbnB1dCBlbGVtZW50IHdpdGggYXV0b2ZpbGwgc3VnZ2VzdGlvbnMuCiAgICAgaWYgKGxp
c3RlbmVyKQpAQCAtMTk4MCw5ICsxOTgwLDkgQEAgdm9pZCBXZWJGcmFtZUltcGw6Om5vdGlmaXlQ
YXNzd29yZExpc3RlbgogfQogCiBXZWJQYXNzd29yZEF1dG9jb21wbGV0ZUxpc3RlbmVyKiBXZWJG
cmFtZUltcGw6OmdldFBhc3N3b3JkTGlzdGVuZXIoCi0gICAgSFRNTElucHV0RWxlbWVudCogaW5w
dXRFbGVtZW50KQorICAgIGNvbnN0IEhUTUxJbnB1dEVsZW1lbnQqIGlucHV0RWxlbWVudCkKIHsK
LSAgICByZXR1cm4gbV9wYXNzd29yZExpc3RlbmVycy5nZXQoUmVmUHRyPEhUTUxJbnB1dEVsZW1l
bnQ+KGlucHV0RWxlbWVudCkpOworICAgIHJldHVybiBtX3Bhc3N3b3JkTGlzdGVuZXJzLmdldChS
ZWZQdHI8SFRNTElucHV0RWxlbWVudD4oY29uc3RfY2FzdDxIVE1MSW5wdXRFbGVtZW50Kj4oaW5w
dXRFbGVtZW50KSkpOwogfQogCiAvLyBXZWJGcmFtZUltcGwgcHJpdmF0ZSAtLS0tLS0tLS0tLS0t
LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQpJbmRleDogV2ViS2l0
L2Nocm9taXVtL3NyYy9XZWJGcmFtZUltcGwuaAo9PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tLSBXZWJLaXQvY2hyb21p
dW0vc3JjL1dlYkZyYW1lSW1wbC5oCShyZXZpc2lvbiA2MjcwNSkKKysrIFdlYktpdC9jaHJvbWl1
bS9zcmMvV2ViRnJhbWVJbXBsLmgJKHdvcmtpbmcgY29weSkKQEAgLTIzMSw3ICsyMzEsNyBAQCBw
dWJsaWM6CiAgICAgLy8gdXNlciBuYW1lIGlucHV0IGVsZW1lbnQsIG9yIDAgaWYgbm9uZSBhdmFp
bGFibGUuCiAgICAgLy8gTm90ZSB0aGF0IHRoZSByZXR1cm5lZCBsaXN0ZW5lciBpcyBvd25lciBi
eSB0aGUgV2ViRnJhbWVJbXBsIGFuZCBzaG91bGQgbm90CiAgICAgLy8gYmUga2VwdCBhcm91bmQg
YXMgaXQgaXMgZGVsZXRlZCB3aGVuIHRoZSBwYWdlIGdvZXMgYXdheS4KLSAgICBXZWJQYXNzd29y
ZEF1dG9jb21wbGV0ZUxpc3RlbmVyKiBnZXRQYXNzd29yZExpc3RlbmVyKFdlYkNvcmU6OkhUTUxJ
bnB1dEVsZW1lbnQqKTsKKyAgICBXZWJQYXNzd29yZEF1dG9jb21wbGV0ZUxpc3RlbmVyKiBnZXRQ
YXNzd29yZExpc3RlbmVyKGNvbnN0IFdlYkNvcmU6OkhUTUxJbnB1dEVsZW1lbnQqKTsKIAogICAg
IFdlYkZyYW1lQ2xpZW50KiBjbGllbnQoKSBjb25zdCB7IHJldHVybiBtX2NsaWVudDsgfQogICAg
IHZvaWQgc2V0Q2xpZW50KFdlYkZyYW1lQ2xpZW50KiBjbGllbnQpIHsgbV9jbGllbnQgPSBjbGll
bnQ7IH0K
</data>

          </attachment>
      

    </bug>

</bugzilla>