<?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>30148</bug_id>
          
          <creation_ts>2009-10-06 19:54:29 -0700</creation_ts>
          <short_desc>Applying h1 format to text node after HR tag fails to include first letter of text node.</short_desc>
          <delta_ts>2010-03-11 18:47:49 -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>HTML Editing</component>
          <version>528+ (Nightly build)</version>
          <rep_platform>PC</rep_platform>
          <op_sys>OS X 10.5</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>0</everconfirmed>
          <reporter name="Michael Thomas">michaelthomas</reporter>
          <assigned_to name="Nobody">webkit-unassigned</assigned_to>
          <cc>commit-queue</cc>
    
    <cc>enrica</cc>
    
    <cc>eric</cc>
    
    <cc>jparent</cc>
    
    <cc>rniwa</cc>
    
    <cc>sullivan</cc>
    
    <cc>tony</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>152931</commentid>
    <comment_count>0</comment_count>
    <who name="Michael Thomas">michaelthomas</who>
    <bug_when>2009-10-06 19:54:29 -0700</bug_when>
    <thetext>STEPS TO REPRODUCE:
1. Go to midas demo: http://www.mozilla.org/editor/midasdemo/
2. Enter the following HTML: &apos;&lt;hr&gt;test&apos;
3. Place the cursor after the word &apos;test&apos;.
4. Select &apos;Heading 1&apos; from the menu.

RESULT:
The heading style is applied to the entire line except the first character:

&lt;hr&gt;&lt;h1&gt;&lt;span class=&quot;Apple-style-span&quot; style=&quot;font-weight: normal; font-size: medium; &quot;&gt;t&lt;/span&gt;est&lt;/h1&gt;

EXPECTED:
The heading style is applied to the entire line:
&lt;hr&gt;&lt;h1&gt;test&lt;/h1&gt;

Automated test case:

http://www.plexode.com/cgi-bin/eval3.py#ht=%3Cdiv%20id%3D%22editor%22%20contenteditable%3Dtrue%3E%3Chr%3Etest%3C%2Fdiv%3E%0A&amp;ohh=1&amp;ohj=1&amp;jt=var%20div%20%3D%20document.getElementById(&apos;editor&apos;)%3B%0A%0A%2F%2F%20Change%20this%20to%20select%20a%20range%0AselectRange(div.childNodes%5B1%5D%2C%204%2C%20div.childNodes%5B1%5D%2C%204)%3B%0A%0A%2F%2F%20Change%20this%20to%20run%20execCommand%0Adocument.execCommand(&apos;FormatBlock&apos;%2C%20false%2C%20&apos;%3Ch1%3E&apos;)%3B%0A%0Afunction%20selectRange(startNode%2C%20startOffset%2C%20endNode%2C%20endOffset)%20%7B%0A%20%20var%20sel%20%3D%20window.getSelection()%3B%0A%20%20var%20range%20%3D%20null%3B%0A%20%20try%20%7B%0A%20%20%20%20range%20%3D%20sel.getRangeAt(0)%3B%0A%20%20%7D%20catch(ex)%20%7B%0A%20%20%20%20range%20%3D%20document.createRange()%3B%0A%20%20%7D%0A%20%20range.setStart(startNode%2C%20startOffset)%3B%0A%20%20range.setEnd(endNode%2C%20endOffset)%3B%0A%20%20sel.removeAllRanges()%3B%0A%20%20sel.addRange(range)%3B%0A%7D&amp;ojh=1&amp;ojj=1&amp;ms=100&amp;oth=0&amp;otj=0&amp;cex=1</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>183035</commentid>
    <comment_count>1</comment_count>
    <who name="Tony Chang">tony</who>
    <bug_when>2010-01-20 19:16:21 -0800</bug_when>
    <thetext>The patch on bug 32131  fixes this test as well.  It&apos;s another case where we call applyStyle then restore the selection incorrectly.  In this case, we&apos;re off by a character so the selection no longer contains the first letter after the HR tag.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>197444</commentid>
    <comment_count>2</comment_count>
    <who name="Tony Chang">tony</who>
    <bug_when>2010-03-08 21:09:04 -0800</bug_when>
    <thetext>I think this bug is now fixed, but we should add a layout test so it doesn&apos;t regress.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>197789</commentid>
    <comment_count>3</comment_count>
      <attachid>50354</attachid>
    <who name="Ryosuke Niwa">rniwa</who>
    <bug_when>2010-03-09 14:49:40 -0800</bug_when>
    <thetext>Created attachment 50354
adds a test case

We could make this a js test and add more test cases.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>197790</commentid>
    <comment_count>4</comment_count>
      <attachid>50354</attachid>
    <who name="Darin Adler">darin</who>
    <bug_when>2010-03-09 14:50:52 -0800</bug_when>
    <thetext>Comment on attachment 50354
adds a test case

&gt; +This tests removing underline which is applied outside of unsplittable element. We shouldn&apos;t be removing underline.

Huh?

&gt; +&lt;p&gt;This tests removing underline which is applied outside of unsplittable element.  We shouldn&apos;t be removing underline.&lt;/p&gt;

Wrong description here.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>197855</commentid>
    <comment_count>5</comment_count>
      <attachid>50364</attachid>
    <who name="Ryosuke Niwa">rniwa</who>
    <bug_when>2010-03-09 18:52:27 -0800</bug_when>
    <thetext>Created attachment 50364
fixed the test description

(In reply to comment #4)
&gt; (From update of attachment 50354 [details])
&gt; &gt; +&lt;p&gt;This tests removing underline which is applied outside of unsplittable element.  We shouldn&apos;t be removing underline.&lt;/p&gt;
&gt; 
&gt; Wrong description here.

Sorry, I was too careless.  Fixed.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198197</commentid>
    <comment_count>6</comment_count>
      <attachid>50364</attachid>
    <who name="Ryosuke Niwa">rniwa</who>
    <bug_when>2010-03-10 10:28:34 -0800</bug_when>
    <thetext>Comment on attachment 50364
fixed the test description

Added to the commit queue.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198894</commentid>
    <comment_count>7</comment_count>
      <attachid>50364</attachid>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2010-03-11 18:47:44 -0800</bug_when>
    <thetext>Comment on attachment 50364
fixed the test description

Clearing flags on attachment: 50364

Committed r55876: &lt;http://trac.webkit.org/changeset/55876&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>198895</commentid>
    <comment_count>8</comment_count>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2010-03-11 18:47:49 -0800</bug_when>
    <thetext>All reviewed patches have been landed.  Closing bug.</thetext>
  </long_desc>
      
          <attachment
              isobsolete="1"
              ispatch="1"
              isprivate="0"
          >
            <attachid>50354</attachid>
            <date>2010-03-09 14:49:40 -0800</date>
            <delta_ts>2010-03-09 18:52:27 -0800</delta_ts>
            <desc>adds a test case</desc>
            <filename>fix30148</filename>
            <type>text/plain</type>
            <size>2289</size>
            <attacher name="Ryosuke Niwa">rniwa</attacher>
            
              <data encoding="base64">SW5kZXg6IExheW91dFRlc3RzL0NoYW5nZUxvZwo9PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tLSBMYXlvdXRUZXN0cy9D
aGFuZ2VMb2cJKHJldmlzaW9uIDU1NzQ5KQorKysgTGF5b3V0VGVzdHMvQ2hhbmdlTG9nCSh3b3Jr
aW5nIGNvcHkpCkBAIC0xLDMgKzEsMTYgQEAKKzIwMTAtMDMtMDkgIFJ5b3N1a2UgTml3YSAgPHJu
aXdhQHdlYmtpdC5vcmc+CisKKyAgICAgICAgUmV2aWV3ZWQgYnkgTk9CT0RZIChPT1BTISkuCisK
KyAgICAgICAgQXBwbHlpbmcgaDEgZm9ybWF0IHRvIHRleHQgbm9kZSBhZnRlciBIUiB0YWcgZmFp
bHMgdG8gaW5jbHVkZSBmaXJzdCBsZXR0ZXIgb2YgdGV4dCBub2RlLgorICAgICAgICBodHRwczov
L2J1Z3Mud2Via2l0Lm9yZy9zaG93X2J1Zy5jZ2k/aWQ9MzAxNDgKKworCQlUaGlzIGJ1ZyBoYXMg
YmVlbiBmaXhlZCBieSBodHRwOi8vdHJhYy53ZWJraXQub3JnL2NoYW5nZXNldC81NTcwNS4KKwkJ
VGhpcyBwYXRjaCBhZGRzIGEgdGVzdCBjYXNlIHRvIHByZXZlbnQgdGhlIHJlZ3Jlc3Npb24uCisK
KyAgICAgICAgKiBlZGl0aW5nL3N0eWxlL2hlYWRpbmctdGV4dC1hZnRlci1oci1leHBlY3RlZC50
eHQ6IEFkZGVkLgorICAgICAgICAqIGVkaXRpbmcvc3R5bGUvaGVhZGluZy10ZXh0LWFmdGVyLWhy
Lmh0bWw6IEFkZGVkLgorCiAyMDEwLTAzLTA5ICBBbnRvbiBNdWhpbiAgPGFudG9ubUBjaHJvbWl1
bS5vcmc+CiAKICAgICAgICAgUmV2aWV3ZWQgYnkgRGFyaW4gRmlzaGVyLgpJbmRleDogTGF5b3V0
VGVzdHMvZWRpdGluZy9zdHlsZS9oZWFkaW5nLXRleHQtYWZ0ZXItaHItZXhwZWN0ZWQudHh0Cj09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT0KLS0tIExheW91dFRlc3RzL2VkaXRpbmcvc3R5bGUvaGVhZGluZy10ZXh0LWFmdGVy
LWhyLWV4cGVjdGVkLnR4dAkocmV2aXNpb24gMCkKKysrIExheW91dFRlc3RzL2VkaXRpbmcvc3R5
bGUvaGVhZGluZy10ZXh0LWFmdGVyLWhyLWV4cGVjdGVkLnR4dAkocmV2aXNpb24gMCkKQEAgLTAs
MCArMSw2IEBACitUaGlzIHRlc3RzIHJlbW92aW5nIHVuZGVybGluZSB3aGljaCBpcyBhcHBsaWVk
IG91dHNpZGUgb2YgdW5zcGxpdHRhYmxlIGVsZW1lbnQuIFdlIHNob3VsZG4ndCBiZSByZW1vdmlu
ZyB1bmRlcmxpbmUuCisKK3Rlc3QKKworQmVmb3JlOjxocj50ZXN0CitBZnRlcjo8aHI+PGgxPnRl
c3Q8L2gxPgpJbmRleDogTGF5b3V0VGVzdHMvZWRpdGluZy9zdHlsZS9oZWFkaW5nLXRleHQtYWZ0
ZXItaHIuaHRtbAo9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09Ci0tLSBMYXlvdXRUZXN0cy9lZGl0aW5nL3N0eWxlL2hlYWRp
bmctdGV4dC1hZnRlci1oci5odG1sCShyZXZpc2lvbiAwKQorKysgTGF5b3V0VGVzdHMvZWRpdGlu
Zy9zdHlsZS9oZWFkaW5nLXRleHQtYWZ0ZXItaHIuaHRtbAkocmV2aXNpb24gMCkKQEAgLTAsMCAr
MSwyNSBAQAorPGh0bWw+Cis8Ym9keT4KKzxwPlRoaXMgdGVzdHMgcmVtb3ZpbmcgdW5kZXJsaW5l
IHdoaWNoIGlzIGFwcGxpZWQgb3V0c2lkZSBvZiB1bnNwbGl0dGFibGUgZWxlbWVudC4gIFdlIHNo
b3VsZG4ndCBiZSByZW1vdmluZyB1bmRlcmxpbmUuPC9wPgorPGRpdiBpZD0iZSIgY29udGVudGVk
aXRhYmxlPjxocj50ZXN0PC9kaXY+CisKKzx1bD4KKzxsaT5CZWZvcmU6PHNwYW4gaWQ9ImMxIj48
L3NwYW4+PC9saT4KKzxsaT5BZnRlcjo8c3BhbiBpZD0iYzIiPjwvc3Bhbj48L2xpPgorPC91bD4K
KworPHNjcmlwdCB0eXBlPSJ0ZXh0L2phdmFzY3JpcHQiPgorCitpZiAod2luZG93LmxheW91dFRl
c3RDb250cm9sbGVyKQorICAgIGxheW91dFRlc3RDb250cm9sbGVyLmR1bXBBc1RleHQoKTsKKwor
dmFyIGUgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgnZScpOworZG9jdW1lbnQuZ2V0RWxlbWVu
dEJ5SWQoJ2MxJykuYXBwZW5kQ2hpbGQoZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoZS5pbm5lckhU
TUwpKTsKKwordmFyIHMgPSB3aW5kb3cuZ2V0U2VsZWN0aW9uKCk7CitzLnNldFBvc2l0aW9uKGRv
Y3VtZW50LmdldEVsZW1lbnRCeUlkKCdlJyksIDEpOworZG9jdW1lbnQuZXhlY0NvbW1hbmQoImZv
cm1hdGJsb2NrIiwgZmFsc2UsICJoMSIpOworCitkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgnYzIn
KS5hcHBlbmRDaGlsZChkb2N1bWVudC5jcmVhdGVUZXh0Tm9kZShlLmlubmVySFRNTCkpOworCis8
L3NjcmlwdD4K
</data>
<flag name="review"
          id="33477"
          type_id="1"
          status="-"
          setter="darin"
    />
          </attachment>
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>50364</attachid>
            <date>2010-03-09 18:52:27 -0800</date>
            <delta_ts>2010-03-11 18:47:44 -0800</delta_ts>
            <desc>fixed the test description</desc>
            <filename>fix30148b</filename>
            <type>text/plain</type>
            <size>2182</size>
            <attacher name="Ryosuke Niwa">rniwa</attacher>
            
              <data encoding="base64">SW5kZXg6IExheW91dFRlc3RzL0NoYW5nZUxvZwo9PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09Ci0tLSBMYXlvdXRUZXN0cy9D
aGFuZ2VMb2cJKHJldmlzaW9uIDU1NzQ5KQorKysgTGF5b3V0VGVzdHMvQ2hhbmdlTG9nCSh3b3Jr
aW5nIGNvcHkpCkBAIC0xLDMgKzEsMTYgQEAKKzIwMTAtMDMtMDkgIFJ5b3N1a2UgTml3YSAgPHJu
aXdhQHdlYmtpdC5vcmc+CisKKyAgICAgICAgUmV2aWV3ZWQgYnkgTk9CT0RZIChPT1BTISkuCisK
KyAgICAgICAgQXBwbHlpbmcgaDEgZm9ybWF0IHRvIHRleHQgbm9kZSBhZnRlciBIUiB0YWcgZmFp
bHMgdG8gaW5jbHVkZSBmaXJzdCBsZXR0ZXIgb2YgdGV4dCBub2RlLgorICAgICAgICBodHRwczov
L2J1Z3Mud2Via2l0Lm9yZy9zaG93X2J1Zy5jZ2k/aWQ9MzAxNDgKKworICAgICAgICBUaGlzIHBh
dGNoIGFkZHMgYSB0ZXN0IGNhc2UgdG8gdGhlIGFib3ZlIGJ1Zywgd2hpY2ggaGFzIGJlZW4gZml4
ZWQgYnkKKyAgICAgICAgaHR0cDovL3RyYWMud2Via2l0Lm9yZy9jaGFuZ2VzZXQvNTU3MDUuCisK
KyAgICAgICAgKiBlZGl0aW5nL3N0eWxlL2hlYWRpbmctdGV4dC1hZnRlci1oci1leHBlY3RlZC50
eHQ6IEFkZGVkLgorICAgICAgICAqIGVkaXRpbmcvc3R5bGUvaGVhZGluZy10ZXh0LWFmdGVyLWhy
Lmh0bWw6IEFkZGVkLgorCiAyMDEwLTAzLTA5ICBBbnRvbiBNdWhpbiAgPGFudG9ubUBjaHJvbWl1
bS5vcmc+CiAKICAgICAgICAgUmV2aWV3ZWQgYnkgRGFyaW4gRmlzaGVyLgpJbmRleDogTGF5b3V0
VGVzdHMvZWRpdGluZy9zdHlsZS9oZWFkaW5nLXRleHQtYWZ0ZXItaHItZXhwZWN0ZWQudHh0Cj09
PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT0KLS0tIExheW91dFRlc3RzL2VkaXRpbmcvc3R5bGUvaGVhZGluZy10ZXh0LWFmdGVy
LWhyLWV4cGVjdGVkLnR4dAkocmV2aXNpb24gMCkKKysrIExheW91dFRlc3RzL2VkaXRpbmcvc3R5
bGUvaGVhZGluZy10ZXh0LWFmdGVyLWhyLWV4cGVjdGVkLnR4dAkocmV2aXNpb24gMCkKQEAgLTAs
MCArMSw2IEBACitUaGlzIHRlc3RzIGZvcm1hdHRpbmcgYSB0ZXh0IGltbWVkaWF0ZWx5IGFmdGVy
IGhyIHdpdGggaDEgdGFnLgorCit0ZXN0CisKK0JlZm9yZTo8aHI+dGVzdAorQWZ0ZXI6PGhyPjxo
MT50ZXN0PC9oMT4KSW5kZXg6IExheW91dFRlc3RzL2VkaXRpbmcvc3R5bGUvaGVhZGluZy10ZXh0
LWFmdGVyLWhyLmh0bWwKPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09
PT09PT09PT09PT09PT09PT09PT09PT09PQotLS0gTGF5b3V0VGVzdHMvZWRpdGluZy9zdHlsZS9o
ZWFkaW5nLXRleHQtYWZ0ZXItaHIuaHRtbAkocmV2aXNpb24gMCkKKysrIExheW91dFRlc3RzL2Vk
aXRpbmcvc3R5bGUvaGVhZGluZy10ZXh0LWFmdGVyLWhyLmh0bWwJKHJldmlzaW9uIDApCkBAIC0w
LDAgKzEsMjUgQEAKKzxodG1sPgorPGJvZHk+Cis8cD5UaGlzIHRlc3RzIGZvcm1hdHRpbmcgYSB0
ZXh0IGltbWVkaWF0ZWx5IGFmdGVyIGhyIHdpdGggaDEgdGFnLjwvcD4KKzxkaXYgaWQ9ImUiIGNv
bnRlbnRlZGl0YWJsZT48aHI+dGVzdDwvZGl2PgorCis8dWw+Cis8bGk+QmVmb3JlOjxzcGFuIGlk
PSJjMSI+PC9zcGFuPjwvbGk+Cis8bGk+QWZ0ZXI6PHNwYW4gaWQ9ImMyIj48L3NwYW4+PC9saT4K
KzwvdWw+CisKKzxzY3JpcHQgdHlwZT0idGV4dC9qYXZhc2NyaXB0Ij4KKworaWYgKHdpbmRvdy5s
YXlvdXRUZXN0Q29udHJvbGxlcikKKyAgICBsYXlvdXRUZXN0Q29udHJvbGxlci5kdW1wQXNUZXh0
KCk7CisKK3ZhciBlID0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoJ2UnKTsKK2RvY3VtZW50Lmdl
dEVsZW1lbnRCeUlkKCdjMScpLmFwcGVuZENoaWxkKGRvY3VtZW50LmNyZWF0ZVRleHROb2RlKGUu
aW5uZXJIVE1MKSk7CisKK3ZhciBzID0gd2luZG93LmdldFNlbGVjdGlvbigpOworcy5zZXRQb3Np
dGlvbihkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgnZScpLCAxKTsKK2RvY3VtZW50LmV4ZWNDb21t
YW5kKCJmb3JtYXRibG9jayIsIGZhbHNlLCAiaDEiKTsKKworZG9jdW1lbnQuZ2V0RWxlbWVudEJ5
SWQoJ2MyJykuYXBwZW5kQ2hpbGQoZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoZS5pbm5lckhUTUwp
KTsKKworPC9zY3JpcHQ+Cg==
</data>

          </attachment>
      

    </bug>

</bugzilla>