Backed out changeset 367cdcfa611b due to smil reftest failures on opt mac & windows tinderboxen
authorDaniel Holbert <dholbert@cs.stanford.edu>
Fri, 26 Feb 2010 15:43:47 -0800
changeset 38773 61a9334cd00f27eed22fcce38635f00a2bc78834
parent 38757 367cdcfa611b838c95684ebd1704c08daf64882c
child 38774 4690d07cdc1dcf16e32334f2a285d2754f2726b5
push id1
push userroot
push dateMon, 20 Oct 2014 17:29:22 +0000
milestone1.9.3a2pre
backs out367cdcfa611b838c95684ebd1704c08daf64882c
Backed out changeset 367cdcfa611b due to smil reftest failures on opt mac & windows tinderboxen
content/smil/crashtests/483584-1.svg
content/smil/crashtests/483584-2.svg
content/smil/crashtests/crashtests.list
content/svg/content/src/nsSVGElement.cpp
deleted file mode 100644
--- a/content/smil/crashtests/483584-1.svg
+++ /dev/null
@@ -1,8 +0,0 @@
-<svg xmlns="http://www.w3.org/2000/svg"
-     xmlns:xlink="http://www.w3.org/1999/xlink">
-  <g id="s">
-    <circle/>
-    <animateTransform attributeName="transform"/>
-  </g>
-  <use xlink:href="#s"/>
-</svg>
deleted file mode 100644
--- a/content/smil/crashtests/483584-2.svg
+++ /dev/null
@@ -1,117 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!-- =====================================================================-->
-<!-- animate-elem-30-t.svg                                                -->
-<!--                                                                      -->
-<!-- Tests various types of animations on referenced elements.            -->
-<!--                                                                      -->
-<!-- Author : Ola Andersson,  22-Sep-2003                                 -->
-<!--======================================================================-->
-<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1 Tiny//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11-tiny.dtd">
-<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" baseProfile="tiny" id="svg-root" width="480" height="360" viewBox="0 0 480 360">
-
-   <g transform="translate(20) scale(1.3)">   
-      <!-- SILHOUETTES-->
-      <path d="M210 40 C210 40 210 100 170 190" fill="none" stroke="#b4b4b4"/>
-      <path d="M 171 188 l 10 -10 l -10 -4 z" fill="#b4b4b4" stroke="none"/>
-      <polyline fill="none" stroke="#b4b4b4" stroke-width="2" points="200,20 200,40 220,40 220,60"/>
-      <polyline transform="rotate(15)" fill="none" stroke="#b4b4b4" stroke-width="9" points="200,120 200,140 220,140 220,160"/>
-  
-      <line x1="40" y1="50" x2="20" y2="10" stroke="#b4b4b4" stroke-width="3"/>
-      <line x1="160" y1="50" x2="80" y2="10" stroke="#b4b4b4" stroke-width="3"/>
-      <line x1="30" y1="30" x2="120" y2="30" stroke="#b4b4b4"/>
-      <path d="M 120 30 l -10 3 l 0 -6 z" fill="#b4b4b4" stroke="none"/>
-  
-      <line x1="70" y1="70" x2="145" y2="70" stroke="#b4b4b4"/>    
-      <rect x="10" y="60" width="60" height="20" fill="#b4b4b4" stroke="#b4b4b4" stroke-width="2"/>
-      <rect x="145" y="60" width="30" height="40" fill="#b4b4b4" stroke="#b4b4b4" stroke-width="2"/>
-      <path d="M 145 70 l -10 3 l 0 -6 z" fill="#b4b4b4" stroke="none"/>
-  
-      <circle cx="30" cy="100" r="10" fill="#b4b4b4" stroke="#b4b4b4"/>
-      <circle cx="100" cy="195" r="15" fill="#b4b4b4" stroke="#b4b4b4"/>
-      <line x1="37" y1="107" x2="89" y2="184" stroke="#b4b4b4"/>
-      <path d="M 90 185 l -3 -12 l -6 5 z" fill="#b4b4b4" stroke="none"/>
-   
-      <rect x="300" y="10" width="20" height="20" fill="#b4b4b4" stroke="#b4b4b4" stroke-width="2"/>
-      <rect x="300" y="170" width="20" height="40" fill="#b4b4b4" stroke="#b4b4b4" stroke-width="2"/>
-      <line x1="310" y1="30" x2="310" y2="170" stroke="#b4b4b4"/>
-      <path d="M 310 170 l -3 -10 l 6 0 z" fill="#b4b4b4" stroke="none"/>
-   
-      <rect x="230" y="7.5" width="40" height="7.5" fill="#b4b4b4" stroke="none"/>
-      <rect x="230" y="170" width="40" height="30" fill="#b4b4b4" stroke="none"/>
-      <line x1="250" y1="10" x2="250" y2="170" stroke="#b4b4b4"/>
-      <path d="M 250 170 l -3 -10 l 6 0 z" fill="#b4b4b4" stroke="none"/>
-      <!-- END OF SILHOUETTES-->
-      
-      <!-- DEFS-->
-      <defs>
-         <line id="lineID" x1="30" y1="50" x2="10" y2="10" stroke="rgb(16, 93, 140)" stroke-width="3">
-            <animate attributeName="x1" from="30" to="90" begin="0" dur="3" fill="freeze"/>
-         </line>
-      </defs>
-   
-      <defs>
-         <rect id="rectID" x="10" y="60" width="60" height="20" fill="blue" stroke="black" stroke-width="2">
-            <animateColor attributeName="fill" from="white" to="rgb(16, 93, 140)" begin="0" dur="3" fill="freeze"/>
-            <animate attributeName="height" from="20" to="40" begin="0" dur="3" fill="freeze"/>
-         </rect>
-      </defs>
-   
-      <defs>
-         <circle id="circleID" cx="20" cy="100" r="10" fill="rgb(16, 93, 140)" stroke="black" transform="">
-            <animate attributeName="cy" from="100" to="130" begin="0" dur="3" fill="freeze"/>
-            <animateTransform attributeName="transform" type="scale" from="1" to="1.5" additive="sum" begin="0" dur="3" fill="freeze"/>
-         </circle>
-      </defs>
-   
-      <defs>
-         <polyline id="polylineID" fill="none" stroke="rgb(16, 93, 140)" stroke-width="2" points="200,20 200,40 220,40 220,60">
-            <animateMotion path="M 0 0 l 0 100" begin="0" dur="3" fill="freeze"/>
-            <animate attributeName="stroke-width" from="2" to="9" begin="0" dur="3" fill="freeze"/>
-         </polyline>
-      </defs>
-   
-      <defs>
-         <polygon id="polygonID" fill="green" stroke="black" points="240,20 240,40 260,40 260,20" stroke-width="2">   
-            <animate attributeName="fill" from="white" to="rgb(16, 93, 140)" begin="0" dur="3" fill="freeze"/>
-         </polygon>
-      </defs>
-   
-      <defs>
-         <image id="imageID" x="230" y="20" width="40" height="80" xlink:href="">
-            <animate attributeName="y" from="5" to="145" begin="0" dur="3" fill="freeze"/>
-         </image>
-      </defs>      
-      <!-- END OF DEFS-->
-      
-      <!-- ACTUAL TEST CONTENT-->
-      <use xlink:href="#lineID">
-         <animate attributeName="x" from="10" to="70" begin="0" dur="3" fill="freeze"/>
-      </use>   
-      
-      <use xlink:href="#rectID" transform="">
-         <animateTransform attributeName="transform" type="translate" from="0 0" to="140 0" begin="0" dur="3" fill="freeze"/>
-         <animateTransform attributeName="transform" type="scale" from="1 1" to="0.5 1" begin="0" dur="3" additive="sum" fill="freeze"/>
-      </use>   
-   
-      <use xlink:href="#circleID">
-         <animate attributeName="x" from="10" to="70" begin="0" dur="3" fill="freeze"/>
-      </use>
-   
-      <use xlink:href="#polylineID" transform="">
-         <animateTransform attributeName="transform" type="rotate" from="0" to="15" additive="sum" begin="0" dur="3" fill="freeze"/>
-      </use>   
-   
-      <use x="60" y="-10" xlink:href="#polygonID" transform="">
-         <animateMotion path="M 0 0 l 0 150" begin="0" dur="3" fill="freeze"/>
-         <animateTransform attributeName="transform" type="scale" from="1 1" to="1 2" begin="0" dur="3" additive="sum" fill="freeze"/>
-      </use>
-   
-      <use xlink:href="#imageID" transform="">
-         <animateTransform attributeName="transform" type="scale" from="1 .25" to="1 1" begin="0" dur="3" additive="sum" fill="freeze"/>
-      </use>
-      <!-- END OF ACTUAL TEST CONTENT-->
-   </g>
-   
-   <text id="revision" x="10" y="340" font-size="40" stroke="none" fill="black">$Revision: 1.6 $</text>
-   <rect id="test-frame" x="1" y="1" width="478" height="358" fill="none" stroke="#000000"/>
-</svg>
\ No newline at end of file
--- a/content/smil/crashtests/crashtests.list
+++ b/content/smil/crashtests/crashtests.list
@@ -1,10 +1,8 @@
-load 483584-1.svg
-load 483584-2.svg
 load 523188-1.svg
 load 525099-1.svg
 load 526536-1.svg
 load 526875-1.svg
 load 526875-2.svg
 load 529387-1.xhtml
 load 537157-1.svg
 load 547333-1.svg
--- a/content/svg/content/src/nsSVGElement.cpp
+++ b/content/svg/content/src/nsSVGElement.cpp
@@ -1230,16 +1230,20 @@ nsSVGElement::DidAnimateLength(PRUint8 a
                             *info.mLengthInfo[aAttrEnum].mName,
                             nsIDOMMutationEvent::MODIFICATION);
   }
 }
 
 void
 nsSVGElement::GetAnimatedLengthValues(float *aFirst, ...)
 {
+#ifdef MOZ_SMIL
+  FlushAnimations();
+#endif
+
   LengthAttributesInfo info = GetLengthInfo();
 
   NS_ASSERTION(info.mLengthCount > 0,
                "GetAnimatedLengthValues on element with no length attribs");
 
   nsSVGSVGElement *ctx = nsnull;
 
   float *f = aFirst;