mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-26 14:46:02 +00:00
Bug 320622 - removeAttribute doesn't effect some underlying DOM properties. r+sr+a=roc
This commit is contained in:
parent
14b19e8184
commit
a8ab6d3130
@ -41,51 +41,9 @@
|
||||
#include "nsSVGAnimatedString.h"
|
||||
#include "nsContentUtils.h"
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////////
|
||||
// nsSVGAnimatedString
|
||||
|
||||
class nsSVGAnimatedString : public nsIDOMSVGAnimatedString,
|
||||
public nsSVGValue
|
||||
{
|
||||
protected:
|
||||
friend nsresult NS_NewSVGAnimatedString(nsIDOMSVGAnimatedString** result);
|
||||
nsSVGAnimatedString();
|
||||
~nsSVGAnimatedString();
|
||||
void Init();
|
||||
|
||||
public:
|
||||
// nsISupports interface:
|
||||
NS_DECL_ISUPPORTS
|
||||
|
||||
// nsIDOMSVGAnimatedString interface:
|
||||
NS_DECL_NSIDOMSVGANIMATEDSTRING
|
||||
|
||||
// remainder of nsISVGValue interface:
|
||||
NS_IMETHOD SetValueString(const nsAString& aValue);
|
||||
NS_IMETHOD GetValueString(nsAString& aValue);
|
||||
|
||||
protected:
|
||||
nsString mBaseVal;
|
||||
};
|
||||
|
||||
|
||||
//----------------------------------------------------------------------
|
||||
// Implementation
|
||||
|
||||
nsSVGAnimatedString::nsSVGAnimatedString()
|
||||
{
|
||||
}
|
||||
|
||||
nsSVGAnimatedString::~nsSVGAnimatedString()
|
||||
{
|
||||
}
|
||||
|
||||
void
|
||||
nsSVGAnimatedString::Init()
|
||||
{
|
||||
}
|
||||
|
||||
//----------------------------------------------------------------------
|
||||
// nsISupports methods:
|
||||
|
||||
@ -145,6 +103,15 @@ nsSVGAnimatedString::GetAnimVal(nsAString & aAnimVal)
|
||||
return NS_OK;
|
||||
}
|
||||
|
||||
/* [noscript] void Clear(); */
|
||||
NS_IMETHODIMP
|
||||
nsSVGAnimatedString::Clear()
|
||||
{
|
||||
mBaseVal.Truncate();
|
||||
return NS_OK;
|
||||
}
|
||||
|
||||
|
||||
////////////////////////////////////////////////////////////////////////
|
||||
// Exported creation functions
|
||||
|
||||
@ -157,8 +124,6 @@ NS_NewSVGAnimatedString(nsIDOMSVGAnimatedString** aResult)
|
||||
if(!animatedString) return NS_ERROR_OUT_OF_MEMORY;
|
||||
NS_ADDREF(animatedString);
|
||||
|
||||
animatedString->Init();
|
||||
|
||||
*aResult = (nsIDOMSVGAnimatedString*) animatedString;
|
||||
|
||||
return NS_OK;
|
||||
|
@ -40,10 +40,32 @@
|
||||
#define __NS_SVGANIMATEDSTRING_H__
|
||||
|
||||
#include "nsIDOMSVGAnimatedString.h"
|
||||
#include "nsSVGValue.h"
|
||||
|
||||
nsresult NS_NewSVGAnimatedString(nsIDOMSVGAnimatedString** result);
|
||||
|
||||
////////////////////////////////////////////////////////////////////////
|
||||
// nsSVGAnimatedString
|
||||
|
||||
class nsSVGAnimatedString : public nsIDOMSVGAnimatedString,
|
||||
public nsSVGValue
|
||||
{
|
||||
protected:
|
||||
friend nsresult NS_NewSVGAnimatedString(nsIDOMSVGAnimatedString** result);
|
||||
|
||||
public:
|
||||
// nsISupports interface:
|
||||
NS_DECL_ISUPPORTS
|
||||
|
||||
// nsIDOMSVGAnimatedString interface:
|
||||
NS_DECL_NSIDOMSVGANIMATEDSTRING
|
||||
|
||||
// remainder of nsISVGValue interface:
|
||||
NS_IMETHOD SetValueString(const nsAString& aValue);
|
||||
NS_IMETHOD GetValueString(nsAString& aValue);
|
||||
|
||||
protected:
|
||||
nsString mBaseVal;
|
||||
};
|
||||
|
||||
#endif //__NS_SVGANIMATEDSTRING_H__
|
||||
|
@ -103,3 +103,11 @@ nsSVGClassValue::GetAnimVal(nsAString & aAnimVal)
|
||||
|
||||
return NS_OK;
|
||||
}
|
||||
|
||||
/* [noscript] void Clear(); */
|
||||
NS_IMETHODIMP
|
||||
nsSVGClassValue::Clear()
|
||||
{
|
||||
mBaseVal.Reset();
|
||||
return NS_OK;
|
||||
}
|
||||
|
@ -69,6 +69,25 @@
|
||||
#include "nsSVGNumber2.h"
|
||||
#include "nsSVGEnum.h"
|
||||
#include "nsIDOMSVGUnitTypes.h"
|
||||
#include "nsIDOMSVGAngle.h"
|
||||
#include "nsIDOMSVGAnimatedAngle.h"
|
||||
#include "nsIDOMSVGAnimatedBoolean.h"
|
||||
#include "nsIDOMSVGAnimatedInteger.h"
|
||||
#include "nsIDOMSVGLength.h"
|
||||
#include "nsIDOMSVGLengthList.h"
|
||||
#include "nsIDOMSVGAnimatedLengthList.h"
|
||||
#include "nsIDOMSVGNumberList.h"
|
||||
#include "nsIDOMSVGAnimatedNumberList.h"
|
||||
#include "nsIDOMSVGPointList.h"
|
||||
#include "nsIDOMSVGAnimatedPoints.h"
|
||||
#include "nsIDOMSVGPresAspectRatio.h"
|
||||
#include "nsIDOMSVGAnimPresAspRatio.h"
|
||||
#include "nsIDOMSVGTransformList.h"
|
||||
#include "nsIDOMSVGAnimTransformList.h"
|
||||
#include "nsIDOMSVGAnimatedString.h"
|
||||
#include "nsIDOMSVGAnimatedRect.h"
|
||||
#include "nsSVGRect.h"
|
||||
#include "nsSVGAnimatedString.h"
|
||||
#include <stdarg.h>
|
||||
|
||||
nsSVGEnumMapping nsSVGElement::sSVGUnitTypesMap[] = {
|
||||
@ -317,6 +336,62 @@ nsSVGElement::UnsetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
// Now check for one of the old style basetypes going away
|
||||
nsCOMPtr<nsISVGValue> svg_value = GetMappedAttribute(aNamespaceID, aName);
|
||||
|
||||
if (svg_value) {
|
||||
#ifdef DEBUG_tor
|
||||
nsCOMPtr<nsIDOMSVGAnimatedAngle> a = do_QueryInterface(svg_value);
|
||||
NS_ASSERTION(!a, "must provide element processing for unset angle");
|
||||
|
||||
nsCOMPtr<nsIDOMSVGAnimatedBoolean> b = do_QueryInterface(svg_value);
|
||||
NS_ASSERTION(!b, "must provide element processing for unset boolean");
|
||||
|
||||
nsCOMPtr<nsIDOMSVGAnimatedInteger> i = do_QueryInterface(svg_value);
|
||||
NS_ASSERTION(!i, "must provide element processing for unset integer");
|
||||
#endif
|
||||
|
||||
nsCOMPtr<nsIDOMSVGAnimatedRect> r = do_QueryInterface(svg_value);
|
||||
if (r) {
|
||||
nsIDOMSVGRect *rect;
|
||||
r->GetBaseVal(&rect);
|
||||
static_cast<nsSVGRect*>(rect)->Clear();
|
||||
}
|
||||
nsCOMPtr<nsIDOMSVGAnimatedPreserveAspectRatio> ar = do_QueryInterface(svg_value);
|
||||
if (ar) {
|
||||
nsIDOMSVGPreserveAspectRatio *par;
|
||||
ar->GetBaseVal(&par);
|
||||
par->SetAlign(nsIDOMSVGPreserveAspectRatio::SVG_PRESERVEASPECTRATIO_XMIDYMID);
|
||||
par->SetMeetOrSlice(nsIDOMSVGPreserveAspectRatio::SVG_MEETORSLICE_MEET);
|
||||
}
|
||||
nsCOMPtr<nsIDOMSVGAnimatedString> s = do_QueryInterface(svg_value);
|
||||
if (s) {
|
||||
s->Clear();
|
||||
}
|
||||
nsCOMPtr<nsIDOMSVGPointList> pl = do_QueryInterface(svg_value);
|
||||
if (pl) {
|
||||
pl->Clear();
|
||||
}
|
||||
nsCOMPtr<nsIDOMSVGAnimatedLengthList> ll = do_QueryInterface(svg_value);
|
||||
if (ll) {
|
||||
nsIDOMSVGLengthList *lengthlist;
|
||||
ll->GetBaseVal(&lengthlist);
|
||||
lengthlist->Clear();
|
||||
}
|
||||
nsCOMPtr<nsIDOMSVGAnimatedNumberList> nl = do_QueryInterface(svg_value);
|
||||
if (nl) {
|
||||
nsIDOMSVGNumberList *numberlist;
|
||||
nl->GetBaseVal(&numberlist);
|
||||
numberlist->Clear();
|
||||
}
|
||||
nsCOMPtr<nsIDOMSVGAnimatedTransformList> tl = do_QueryInterface(svg_value);
|
||||
if (tl) {
|
||||
nsIDOMSVGTransformList *transform;
|
||||
tl->GetBaseVal(&transform);
|
||||
transform->Clear();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -238,6 +238,20 @@ nsSVGFilterElement::SetAttr(PRInt32 aNameSpaceID, nsIAtom* aName,
|
||||
return rv;
|
||||
}
|
||||
|
||||
nsresult
|
||||
nsSVGFilterElement::UnsetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
PRBool aNotify)
|
||||
{
|
||||
if (aName == nsGkAtoms::filterRes && aNamespaceID == kNameSpaceID_None) {
|
||||
mFilterResX->SetBaseVal(0);
|
||||
mFilterResY->SetBaseVal(0);
|
||||
|
||||
return nsGenericElement::UnsetAttr(aNamespaceID, aName, aNotify);
|
||||
}
|
||||
|
||||
return nsSVGFilterElementBase::UnsetAttr(aNamespaceID, aName, aNotify);
|
||||
}
|
||||
|
||||
NS_IMETHODIMP_(PRBool)
|
||||
nsSVGFilterElement::IsAttributeMapped(const nsIAtom* name) const
|
||||
{
|
||||
|
@ -79,6 +79,8 @@ public:
|
||||
virtual nsresult SetAttr(PRInt32 aNameSpaceID, nsIAtom* aName,
|
||||
nsIAtom* aPrefix, const nsAString& aValue,
|
||||
PRBool aNotify);
|
||||
virtual nsresult UnsetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
PRBool aNotify);
|
||||
|
||||
virtual nsresult Clone(nsINodeInfo *aNodeInfo, nsINode **aResult) const;
|
||||
NS_IMETHOD_(PRBool) IsAttributeMapped(const nsIAtom* aAttribute) const;
|
||||
|
@ -3010,6 +3010,8 @@ public:
|
||||
const nsAString& aValue,
|
||||
nsAttrValue& aResult);
|
||||
virtual nsresult Clone(nsINodeInfo *aNodeInfo, nsINode **aResult) const;
|
||||
virtual nsresult UnsetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
PRBool aNotify);
|
||||
|
||||
protected:
|
||||
virtual NumberAttributesInfo GetNumberInfo();
|
||||
@ -3234,6 +3236,18 @@ nsSVGFETurbulenceElement::ParseAttribute(PRInt32 aNameSpaceID, nsIAtom* aName,
|
||||
aValue, aResult);
|
||||
}
|
||||
|
||||
nsresult
|
||||
nsSVGFETurbulenceElement::UnsetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
PRBool aNotify)
|
||||
{
|
||||
if (aNamespaceID == kNameSpaceID_None && aName == nsGkAtoms::numOctaves) {
|
||||
mNumOctaves->SetBaseVal(1);
|
||||
return nsGenericElement::UnsetAttr(aNamespaceID, aName, aNotify);
|
||||
}
|
||||
|
||||
return nsSVGFETurbulenceElementBase::UnsetAttr(aNamespaceID, aName, aNotify);
|
||||
}
|
||||
|
||||
NS_IMETHODIMP
|
||||
nsSVGFETurbulenceElement::Filter(nsSVGFilterInstance *instance)
|
||||
{
|
||||
@ -3835,6 +3849,8 @@ public:
|
||||
const nsAString& aValue,
|
||||
nsAttrValue& aResult);
|
||||
virtual nsresult Clone(nsINodeInfo *aNodeInfo, nsINode **aResult) const;
|
||||
virtual nsresult UnsetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
PRBool aNotify);
|
||||
|
||||
protected:
|
||||
virtual PRBool OperatesOnPremultipledAlpha() {
|
||||
@ -3951,7 +3967,7 @@ nsSVGFEConvolveMatrixElement::Init()
|
||||
NS_ENSURE_SUCCESS(rv,rv);
|
||||
}
|
||||
|
||||
// DOM property: targetY , #IMPLIED attrib: targetY
|
||||
// DOM property: preserveAlpha , #IMPLIED attrib: preserveAlpha
|
||||
{
|
||||
rv = NS_NewSVGAnimatedBoolean(getter_AddRefs(mPreserveAlpha), PR_FALSE);
|
||||
NS_ENSURE_SUCCESS(rv,rv);
|
||||
@ -4119,6 +4135,35 @@ nsSVGFEConvolveMatrixElement::ParseAttribute(PRInt32 aNameSpaceID, nsIAtom* aNam
|
||||
aValue, aResult);
|
||||
}
|
||||
|
||||
nsresult
|
||||
nsSVGFEConvolveMatrixElement::UnsetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
PRBool aNotify)
|
||||
{
|
||||
if (aNamespaceID == kNameSpaceID_None) {
|
||||
PRBool processed = PR_FALSE;
|
||||
if (aName == nsGkAtoms::order) {
|
||||
mOrderX->SetBaseVal(0);
|
||||
mOrderY->SetBaseVal(0);
|
||||
processed = PR_TRUE;
|
||||
} else if (aName == nsGkAtoms::targetX) {
|
||||
mTargetX->SetBaseVal(0);
|
||||
processed = PR_TRUE;
|
||||
} else if (aName == nsGkAtoms::targetY) {
|
||||
mTargetY->SetBaseVal(0);
|
||||
processed = PR_TRUE;
|
||||
} else if (aName == nsGkAtoms::preserveAlpha) {
|
||||
mPreserveAlpha->SetBaseVal(PR_FALSE);
|
||||
processed = PR_TRUE;
|
||||
}
|
||||
|
||||
if (processed) {
|
||||
return nsGenericElement::UnsetAttr(aNamespaceID, aName, aNotify);
|
||||
}
|
||||
}
|
||||
|
||||
return nsSVGFEConvolveMatrixElementBase::UnsetAttr(aNamespaceID, aName, aNotify);
|
||||
}
|
||||
|
||||
#define BOUND(val, min, max) \
|
||||
PR_MIN(PR_MAX(val, min), max)
|
||||
|
||||
|
@ -306,7 +306,13 @@ nsSVGMarkerElement::UnsetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
vb->SetHeight(mLengthAttributes[MARKERHEIGHT].GetAnimValue(mCoordCtx));
|
||||
} else if (aName == nsGkAtoms::orient) {
|
||||
mOrientType.SetBaseValue(SVG_MARKER_ORIENT_AUTO, this, PR_FALSE);
|
||||
nsIDOMSVGAngle *angle;
|
||||
mOrient->GetBaseVal(&angle);
|
||||
angle->NewValueSpecifiedUnits(nsIDOMSVGAngle::SVG_ANGLETYPE_UNSPECIFIED,
|
||||
0.0f);
|
||||
}
|
||||
|
||||
return nsGenericElement::UnsetAttr(aNamespaceID, aName, aNotify);
|
||||
}
|
||||
|
||||
return nsSVGMarkerElementBase::UnsetAttr(aNamespaceID, aName, aNotify);
|
||||
|
@ -442,6 +442,24 @@ nsSVGPathElement::BeforeSetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
aValue, aNotify);
|
||||
}
|
||||
|
||||
nsresult
|
||||
nsSVGPathElement::UnsetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
PRBool aNotify)
|
||||
{
|
||||
if (aNamespaceID == kNameSpaceID_None && aName == nsGkAtoms::d) {
|
||||
if (mSegments) {
|
||||
NS_REMOVE_SVGVALUE_OBSERVER(mSegments);
|
||||
mSegments = nsnull;
|
||||
}
|
||||
|
||||
mPathData.Clear();
|
||||
|
||||
return nsGenericElement::UnsetAttr(aNamespaceID, aName, aNotify);
|
||||
}
|
||||
|
||||
return nsSVGPathElementBase::UnsetAttr(aNamespaceID, aName, aNotify);
|
||||
}
|
||||
|
||||
NS_IMETHODIMP
|
||||
nsSVGPathElement::DidModifySVGObservable(nsISVGValue* observable,
|
||||
nsISVGValue::modificationType aModType)
|
||||
|
@ -56,10 +56,9 @@ public:
|
||||
nsSVGPathList() : mArguments(nsnull), mNumCommands(0), mNumArguments(0) {}
|
||||
~nsSVGPathList() { Clear(); }
|
||||
void Playback(gfxContext *aCtx);
|
||||
|
||||
protected:
|
||||
void Clear();
|
||||
|
||||
protected:
|
||||
float *mArguments;
|
||||
PRUint32 mNumCommands;
|
||||
PRUint32 mNumArguments;
|
||||
@ -106,13 +105,17 @@ public:
|
||||
|
||||
virtual already_AddRefed<gfxFlattenedPath> GetFlattenedPath(nsIDOMSVGMatrix *aMatrix);
|
||||
|
||||
// nsIContent interface
|
||||
virtual nsresult Clone(nsINodeInfo *aNodeInfo, nsINode **aResult) const;
|
||||
virtual nsresult BeforeSetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
const nsAString* aValue, PRBool aNotify);
|
||||
virtual nsresult UnsetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
PRBool aNotify);
|
||||
|
||||
protected:
|
||||
|
||||
// nsSVGElement method
|
||||
virtual NumberAttributesInfo GetNumberInfo();
|
||||
virtual nsresult BeforeSetAttr(PRInt32 aNamespaceID, nsIAtom* aName,
|
||||
const nsAString* aValue, PRBool aNotify);
|
||||
|
||||
// Helper for lazily creating pathseg list
|
||||
nsresult CreatePathSegList();
|
||||
|
@ -48,30 +48,6 @@
|
||||
#include "nsContentUtils.h"
|
||||
#include "nsDOMError.h"
|
||||
|
||||
////////////////////////////////////////////////////////////////////////
|
||||
// nsSVGRect class
|
||||
|
||||
class nsSVGRect : public nsIDOMSVGRect,
|
||||
public nsSVGValue
|
||||
{
|
||||
public:
|
||||
nsSVGRect(float x=0.0f, float y=0.0f, float w=0.0f, float h=0.0f);
|
||||
|
||||
// nsISupports interface:
|
||||
NS_DECL_ISUPPORTS
|
||||
|
||||
// nsIDOMSVGRect interface:
|
||||
NS_DECL_NSIDOMSVGRECT
|
||||
|
||||
// nsISVGValue interface:
|
||||
NS_IMETHOD SetValueString(const nsAString& aValue);
|
||||
NS_IMETHOD GetValueString(nsAString& aValue);
|
||||
|
||||
|
||||
protected:
|
||||
float mX, mY, mWidth, mHeight;
|
||||
};
|
||||
|
||||
//----------------------------------------------------------------------
|
||||
// implementation:
|
||||
|
||||
@ -80,6 +56,12 @@ nsSVGRect::nsSVGRect(float x, float y, float w, float h)
|
||||
{
|
||||
}
|
||||
|
||||
void
|
||||
nsSVGRect::Clear()
|
||||
{
|
||||
mX = mY = mWidth = mHeight = 0.0f;
|
||||
}
|
||||
|
||||
//----------------------------------------------------------------------
|
||||
// nsISupports methods:
|
||||
|
||||
|
@ -41,10 +41,9 @@
|
||||
#define __NS_SVGRECT_H__
|
||||
|
||||
#include "nsIDOMSVGRect.h"
|
||||
#include "nsSVGValue.h"
|
||||
#include "gfxRect.h"
|
||||
|
||||
class nsIDOMSVGLength;
|
||||
|
||||
nsresult
|
||||
NS_NewSVGRect(nsIDOMSVGRect** result,
|
||||
float x=0.0f, float y=0.0f,
|
||||
@ -58,4 +57,29 @@ NS_NewSVGReadonlyRect(nsIDOMSVGRect** result,
|
||||
float x=0.0f, float y=0.0f,
|
||||
float width=0.0f, float height=0.0f);
|
||||
|
||||
////////////////////////////////////////////////////////////////////////
|
||||
// nsSVGRect class
|
||||
|
||||
class nsSVGRect : public nsIDOMSVGRect,
|
||||
public nsSVGValue
|
||||
{
|
||||
public:
|
||||
nsSVGRect(float x=0.0f, float y=0.0f, float w=0.0f, float h=0.0f);
|
||||
|
||||
// nsISupports interface:
|
||||
NS_DECL_ISUPPORTS
|
||||
|
||||
// nsIDOMSVGRect interface:
|
||||
NS_DECL_NSIDOMSVGRECT
|
||||
|
||||
// nsISVGValue interface:
|
||||
NS_IMETHOD SetValueString(const nsAString& aValue);
|
||||
NS_IMETHOD GetValueString(nsAString& aValue);
|
||||
|
||||
void Clear();
|
||||
|
||||
protected:
|
||||
float mX, mY, mWidth, mHeight;
|
||||
};
|
||||
|
||||
#endif //__NS_SVGRECT_H__
|
||||
|
@ -38,11 +38,14 @@
|
||||
|
||||
#include "domstubs.idl"
|
||||
|
||||
[scriptable, uuid(36f18f12-61a9-4529-8fa9-30050bd6ac00)]
|
||||
[scriptable, uuid(4afb42f4-9969-483d-9b90-59ddba047492)]
|
||||
interface nsIDOMSVGAnimatedString
|
||||
: nsISupports
|
||||
{
|
||||
attribute DOMString baseVal;
|
||||
// raises DOMException on setting
|
||||
readonly attribute DOMString animVal;
|
||||
|
||||
/* internal method used for resetting strings during attribute removal */
|
||||
[noscript] void Clear();
|
||||
};
|
||||
|
Loading…
x
Reference in New Issue
Block a user