author | Mats Palmgren <matspal@gmail.com> |
Sun, 20 Apr 2014 19:35:33 +0000 | |
changeset 197859 | 581208970e99444a504e64f3252095779afa11fc |
parent 197841 | 8a8c87fcd2d900c15c9de53a47b7e1aac48b5ffe |
child 197860 | ea214ef03c3fc40f630fb16f333d05502692a6d5 |
push id | 3624 |
push user | asasaki@mozilla.com |
push date | Mon, 09 Jun 2014 21:49:01 +0000 |
treeherder | mozilla-beta@b1a5da15899a [default view] [failures only] |
perfherder | [talos] [build metrics] [platform microbench] (compared to previous push) |
bugs | 988653, 613659 |
milestone | 31.0a1 |
first release with | nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
|
last release without | nightly linux32
nightly linux64
nightly mac
nightly win32
nightly win64
|
layout/base/nsCSSRendering.cpp | file | annotate | diff | comparison | revisions | |
layout/reftests/css-break/box-decoration-break-border-image-ref.html | file | annotate | diff | comparison | revisions | |
layout/reftests/css-break/box-decoration-break-border-image.html | file | annotate | diff | comparison | revisions | |
layout/reftests/css-break/reftest.list | file | annotate | diff | comparison | revisions |
--- a/layout/base/nsCSSRendering.cpp +++ b/layout/base/nsCSSRendering.cpp @@ -368,18 +368,17 @@ struct ColorStop { }; /* Local functions */ static void DrawBorderImage(nsPresContext* aPresContext, nsRenderingContext& aRenderingContext, nsIFrame* aForFrame, const nsRect& aBorderArea, const nsStyleBorder& aStyleBorder, - const nsRect& aDirtyRect, - int aSkipSides); + const nsRect& aDirtyRect); static nscolor MakeBevelColor(mozilla::css::Side whichSide, uint8_t style, nscolor aBackgroundColor, nscolor aBorderColor); static InlineBackgroundData* gInlineBGData = nullptr; // Initialize any static variables used by nsCSSRendering. @@ -627,34 +626,34 @@ nsCSSRendering::PaintBorderWithStyleBord if (displayData->mAppearance) { nsITheme *theme = aPresContext->GetTheme(); if (theme && theme->ThemeSupportsWidget(aPresContext, aForFrame, displayData->mAppearance)) return; // Let the theme handle it. } if (aStyleBorder.IsBorderImageLoaded()) { DrawBorderImage(aPresContext, aRenderingContext, aForFrame, - aBorderArea, aStyleBorder, aDirtyRect, aSkipSides); + aBorderArea, aStyleBorder, aDirtyRect); return; } // Get our style context's color struct. const nsStyleColor* ourColor = aStyleContext->StyleColor(); // In NavQuirks mode we want to use the parent's context as a starting point // for determining the background color. bool quirks = aPresContext->CompatibilityMode() == eCompatibility_NavQuirks; nsIFrame* bgFrame = FindNonTransparentBackgroundFrame(aForFrame, quirks); nsStyleContext* bgContext = bgFrame->StyleContext(); nscolor bgColor = bgContext->GetVisitedDependentColor(eCSSProperty_background_color); nsMargin border = aStyleBorder.GetComputedBorder(); - if (0 == border.left && 0 == border.right && - 0 == border.top && 0 == border.bottom) { + if ((0 == border.left) && (0 == border.right) && + (0 == border.top) && (0 == border.bottom)) { // Empty border area return; } // Compute the outermost boundary of the area that might be painted. // Same coordinate space as aBorderArea & aBGClipRect. nsRect joinedBorderArea = ::BoxDecorationRectForBorder(aForFrame, aBorderArea, &aStyleBorder); @@ -3197,18 +3196,17 @@ nsCSSRendering::AreAllBackgroundImagesDe } static void DrawBorderImage(nsPresContext* aPresContext, nsRenderingContext& aRenderingContext, nsIFrame* aForFrame, const nsRect& aBorderArea, const nsStyleBorder& aStyleBorder, - const nsRect& aDirtyRect, - int aSkipSides) + const nsRect& aDirtyRect) { NS_PRECONDITION(aStyleBorder.IsBorderImageLoaded(), "drawing border image that isn't successfully loaded"); if (aDirtyRect.IsEmpty()) return; nsImageRenderer renderer(aForFrame, &aStyleBorder.mBorderImageSource, 0); @@ -3220,49 +3218,20 @@ DrawBorderImage(nsPresContext* aPr // different style, they'll potentially have the wrong size for the // border too. aForFrame->AssociateImage(aStyleBorder.mBorderImageSource, aPresContext); if (!renderer.PrepareImage()) { return; } - // NOTE: no Save() yet, we do that later by calling autoSR.EnsureSaved() - // in case we need it. - gfxContextAutoSaveRestore autoSR; - // Determine the border image area, which by default corresponds to the // border box but can be modified by 'border-image-outset'. - // Note that 'border-radius' do not apply to 'border-image' borders per - // <http://dev.w3.org/csswg/css-backgrounds/#corner-clipping>. - nsRect borderImgArea; - nsMargin borderWidths(aStyleBorder.GetComputedBorder()); - nsMargin imageOutset(aStyleBorder.GetImageOutset()); - if (::IsBoxDecorationSlice(aStyleBorder) && aSkipSides != 0) { - borderImgArea = - ::BoxDecorationRectForBorder(aForFrame, aBorderArea, &aStyleBorder); - if (borderImgArea.IsEqualEdges(aBorderArea)) { - // No need for a clip, just skip the sides we don't want. - ::ApplySkipSides(aSkipSides, &borderWidths); - ::ApplySkipSides(aSkipSides, &imageOutset); - borderImgArea.Inflate(imageOutset); - } else { - // We're drawing borders around the joined continuation boxes so we need - // to clip that to the slice that we want for this frame. - borderImgArea.Inflate(imageOutset); - ::ApplySkipSides(aSkipSides, &imageOutset); - nsRect clip = aBorderArea; - clip.Inflate(imageOutset); - autoSR.EnsureSaved(aRenderingContext.ThebesContext()); - aRenderingContext.IntersectClip(clip); - } - } else { - borderImgArea = aBorderArea; - borderImgArea.Inflate(imageOutset); - } + nsRect borderImgArea(aBorderArea); + borderImgArea.Inflate(aStyleBorder.GetImageOutset()); // Calculate the image size used to compute slice points. CSSSizeOrRatio intrinsicSize = renderer.ComputeIntrinsicSize(); nsSize imageSize = nsImageRenderer::ComputeConcreteSize(CSSSizeOrRatio(), intrinsicSize, borderImgArea.Size()); renderer.SetPreferredSize(intrinsicSize, imageSize); @@ -3291,16 +3260,17 @@ DrawBorderImage(nsPresContext* aPr break; } if (value < 0) value = 0; if (value > imgDimension) value = imgDimension; slice.Side(s) = value; + nsMargin borderWidths(aStyleBorder.GetComputedBorder()); coord = aStyleBorder.mBorderImageWidth.Get(s); switch (coord.GetUnit()) { case eStyleUnit_Coord: // absolute dimension value = coord.GetCoordValue(); break; case eStyleUnit_Percent: value = coord.GetPercentValue() * borderDimension; break;
deleted file mode 100644 --- a/layout/reftests/css-break/box-decoration-break-border-image-ref.html +++ /dev/null @@ -1,135 +0,0 @@ -<!DOCTYPE HTML> -<!-- - Any copyright is dedicated to the Public Domain. - http://creativecommons.org/publicdomain/zero/1.0/ ---> -<html> -<head> - <title>Testcase for border-image + box-decoration-break</title> - <link rel="author" title="Mats Palmgren" href="https://bugzilla.mozilla.org/show_bug.cgi?id=988653"> - <meta charset="utf-8"> - <style type="text/css"> -@font-face { - font-family: DejaVuSansMono; - src: url(../fonts/DejaVuSansMono.woff),url(DejaVuSansMono.woff); -} -* { font-family: DejaVuSansMono; } - -html,body { - color:black; background-color:white; font-size:16px; padding:0; padding-left:10px; margin:0; -} - -b1,b2,b3,b4,b5,b6,b7,b8,b9,b10,.b.clone { - border: 5px solid red; - border-image: url(%2FgAIDAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAoUlEQVR42u3bwQ0AIAgEwcOmtXttgScmsxWQCTyp3EysJo61IliwYMGCBUuwYMGCBQuWYMGCBQsWLMGCBQsWLFiCBQsWLFiwBAsWLFiwYAkWLFiwYMESLFiwYMGCpXaVka%2BsO8dmOUNYggULFixYsAQLFixYsGAJFixYsGDBEixYsGDBgiVYsGDBggVLsGDBggULlmDBggULFizBggUL1t89N%2FYEtBGStpoAAAAASUVORK5CYII%3D) 10 10 repeat; - border-image-outset: 7px 3px 5px 9px; -} -.b { - border: 5px solid transparent; - background: pink; -} -.b.clone { - background: pink; - height:28px; -} -.col3 .b.clone { - height:32px; -} - -.columns { - -moz-columns: 2; - width: 200px; - height: 50px; - background: grey; - margin-right: 20px; - margin-bottom: 20px; - float:left; -} -.col3 { - -moz-columns: 3; -} -.vbreak { height:65px; width:41px; } -.h { width:30px;height:30px; background:grey; } -.m { margin-left:15px; } -.col3 .vbreak { height:115px; } -x { display:inline-block; width:31px; height:18px; line-height:1; } -y { display:inline-block; width:47px; height:18px; line-height:1; } -pos1 { position:absolute; top:50px; width:700px; } -pos2 { position:absolute; top:150px; width:700px; } -pos3 { position:absolute; top:380px; width:700px; } -pos4 { position:absolute; top:510px; width:700px; } - -b1,b2,b3,b4,b5,b6,b7,b8,b9,b10,c1,c2,c3,c4,c5,c6,c7,c8,c9,c10,m1,m2,m3,m4,m5,m6,m7,m8,m9,m10 {position:absolute;} -c1,c2,c3,c4,c5,c6,c7,c8,c9,c10 {position:absolute; overflow:hidden; z-index:1;} - - -b1 { top:50px; left:20px; height:65px; width:41px; } -c1 { top:0; left:0; height:88px; width:200px; } - -b2 { top:-38px; left:128px; height:66px; width:41px; } -c2 { top:50px; left:0; height:61px; width:200px; } - -b3 { top:50px; left:240px; height:115px; width:41px; } -c3 { top:0; left:0; height:92px; width:600px; } - -b4 { top:-42px; left:312px; height:115px; width:41px; } -c4 { top:50px; left:0; height:42px; width:600px; } - -b5 { top:-84px; left:384px; height:116px; width:41px; } -c5 { top:50px; left:0; height:100px; width:600px; } - -b6 { top:148px; left:20px; height:19px; z-index:1; } -m6 { top:135px; left:56px; height:55px; width:100px; background:white; z-index:2; } - -b7 { top:30px; left:-36px; width:78px; height:19px; } -c7 { top:170px; left:20px; height:300px; width:200px; } - -b8 { top:30px; left:77px; width:125px; height:19px; } -m8 { top:15px; left:113px; width:125px; height:55px; background:white; } -c8 { top:170px; left:20px; height:300px; width:600px; } - -b9 { top:30px; left:-36px; width:125px; height:19px; } -c9 { top:222px; left:20px; height:300px; width:47px; } - -b10 { top:30px; left:-83px; width:125px; height:19px; } -c10 { top:274px; left:20px; height:300px; width:156px; } - - </style> -</head> -<body> -<c1><b1></b1></c1> -<c2><b2></b2></c2> -<c3><b3></b3></c3> -<c4><b4></b4></c4> -<c5><b5></b5></c5> -<b6><x></x><y></y><br></b6><m6></m6> -<c7><b7><x></x><y></y></b7></c7> -<c8><b8><x></x><y></y><y></y></b8><m8></m8></c8> -<c9><b9><x></x><y></y><y></y></b9></c9> -<c10><b10><x></x><y></y><y></y></b10></c10> -<pre>box-decoration-break:slice</pre> - -<pos1> -<div class="columns"><div class="b vbreak slice"></div></div> -<div class="columns col3"><div class="b vbreak slice"></div></div> -</pos1> - -<pos2> -<span class="b slice"><x></x><div class="h"></div><y></y></span> -<span class="b slice m"><x></x><div class="h"></div><y></y><div class="h"></div><y></y></span> - -<pre>box-decoration-break:clone</pre> -</pos2> - -<pos3> -<div class="columns"><div class="b vbreak clone"></div><div class="b vbreak clone"></div></div> -<div class="columns col3"><div class="b vbreak clone"></div><div class="b vbreak clone"></div><div class="b vbreak clone"></div></div> -</pos3> - -<pos4> -<span class="b clone"><x></x></span><div class="h"></div><span class="b clone"><y></y></span> -<span class="b clone m"><x></x></span><div class="h"></div><span class="b clone m"><y></y></span><div class="h"></div><span class="b clone m"><y></y></span> -</pos4> - -</body> -</html>
deleted file mode 100644 --- a/layout/reftests/css-break/box-decoration-break-border-image.html +++ /dev/null @@ -1,83 +0,0 @@ -<!DOCTYPE HTML> -<!-- - Any copyright is dedicated to the Public Domain. - http://creativecommons.org/publicdomain/zero/1.0/ ---> -<html> -<head> - <title>Testcase for border-image + box-decoration-break</title> - <link rel="author" title="Mats Palmgren" href="https://bugzilla.mozilla.org/show_bug.cgi?id=988653"> - <link rel="help" href="http://dev.w3.org/csswg/css-break/#break-decoration"> - <link rel="match" href="box-decoration-break-border-image-ref.html"> - <meta charset="utf-8"> - <style type="text/css"> -@font-face { - font-family: DejaVuSansMono; - src: url(../fonts/DejaVuSansMono.woff),url(DejaVuSansMono.woff); -} -* { font-family: DejaVuSansMono; } - -html,body { - color:black; background-color:white; font-size:16px; padding:0; padding-left:10px; margin:0; -} - -.b { - border: 5px solid red; - border-image: url(%2FgAIDAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAoUlEQVR42u3bwQ0AIAgEwcOmtXttgScmsxWQCTyp3EysJo61IliwYMGCBUuwYMGCBQuWYMGCBQsWLMGCBQsWLFiCBQsWLFiwBAsWLFiwYAkWLFiwYMESLFiwYMGCpXaVka%2BsO8dmOUNYggULFixYsAQLFixYsGAJFixYsGDBEixYsGDBgiVYsGDBggVLsGDBggULlmDBggULFizBggUL1t89N%2FYEtBGStpoAAAAASUVORK5CYII%3D) 10 10 repeat; - background: pink; - border-image-outset: 7px 3px 5px 9px; -} - -.columns { - -moz-columns: 2; - width: 200px; - height: 50px; - background: grey; - margin-right: 20px; - margin-bottom: 20px; - float:left; -} -.col3 { - -moz-columns: 3; -} -.vbreak { height:65px; width:41px; } -.h { width:30px;height:30px; background:grey; } -.m { margin-left:15px; } -.col3 .vbreak { height:115px; } -.clone { box-decoration-break:clone; } -.slice { box-decoration-break:slice; } -x { display:inline-block; width:31px; height:18px; line-height:1; } -y { display:inline-block; width:47px; height:18px; line-height:1; } -pos1 { position:absolute; top:50px; width:700px; } -pos2 { position:absolute; top:150px; width:700px; } -pos3 { position:absolute; top:380px; width:700px; } -pos4 { position:absolute; top:510px; width:700px; } - </style> -</head> -<body> -<pre>box-decoration-break:slice</pre> - -<pos1> -<div class="columns"><div class="b vbreak slice"></div></div> -<div class="columns col3"><div class="b vbreak slice"></div></div> -</pos1> - -<pos2> -<span class="b slice" style="border-style:dashed;"><x></x><div class="h"></div><y></y></span> -<span class="b slice m" style="border-style:dashed;"><x></x><div class="h"></div><y></y><div class="h"></div><y></y></span> - -<pre>box-decoration-break:clone</pre> -</pos2> - -<pos3> -<div class="columns"><div class="b vbreak clone"></div></div> -<div class="columns col3"><div class="b vbreak clone"></div></div> -</pos3> - -<pos4> -<span class="b clone" style="border-style:dashed;"><x></x><div class="h"></div><y></y></span> -<span class="b clone m" style="border-style:dashed;"><x></x><div class="h"></div><y></y><div class="h"></div><y></y></span> -</pos4> - -</body> -</html>
--- a/layout/reftests/css-break/reftest.list +++ b/layout/reftests/css-break/reftest.list @@ -1,5 +1,4 @@ pref(layout.css.box-decoration-break.enabled,true) == box-decoration-break-1.html box-decoration-break-1-ref.html fuzzy(1,20) pref(layout.css.box-decoration-break.enabled,true) == box-decoration-break-with-inset-box-shadow-1.html box-decoration-break-with-inset-box-shadow-1-ref.html fuzzy(16,460) pref(layout.css.box-decoration-break.enabled,true) == box-decoration-break-with-outset-box-shadow-1.html box-decoration-break-with-outset-box-shadow-1-ref.html -random-if(!gtk2Widget) pref(layout.css.box-decoration-break.enabled,true) HTTP(..) == box-decoration-break-border-image.html box-decoration-break-border-image-ref.html