diff options
author | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
---|---|---|
committer | Matt A. Tobin <mattatobin@localhost.localdomain> | 2018-02-02 04:16:08 -0500 |
commit | 5f8de423f190bbb79a62f804151bc24824fa32d8 (patch) | |
tree | 10027f336435511475e392454359edea8e25895d /dom/svg/SVGAngle.cpp | |
parent | 49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff) | |
download | uxp-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz |
Add m-esr52 at 52.6.0
Diffstat (limited to 'dom/svg/SVGAngle.cpp')
-rw-r--r-- | dom/svg/SVGAngle.cpp | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/dom/svg/SVGAngle.cpp b/dom/svg/SVGAngle.cpp new file mode 100644 index 0000000000..83d5f7ce15 --- /dev/null +++ b/dom/svg/SVGAngle.cpp @@ -0,0 +1,123 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* vim: set ts=8 sts=2 et sw=2 tw=80: */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#include "SVGAngle.h" +#include "nsSVGAngle.h" +#include "mozilla/dom/SVGAngleBinding.h" + +using namespace mozilla; +using namespace mozilla::dom; + +NS_SVG_VAL_IMPL_CYCLE_COLLECTION_WRAPPERCACHED(SVGAngle, mSVGElement) + +NS_IMPL_CYCLE_COLLECTION_ROOT_NATIVE(SVGAngle, AddRef) +NS_IMPL_CYCLE_COLLECTION_UNROOT_NATIVE(SVGAngle, Release) + +JSObject* +SVGAngle::WrapObject(JSContext* aCx, JS::Handle<JSObject*> aGivenProto) +{ + return SVGAngleBinding::Wrap(aCx, this, aGivenProto); +} + +uint16_t +SVGAngle::UnitType() const +{ + if (mType == AnimValue) { + return mVal->mAnimValUnit; + } + return mVal->mBaseValUnit; +} + +float +SVGAngle::Value() const +{ + if (mType == AnimValue) { + return mVal->GetAnimValue(); + } + return mVal->GetBaseValue(); +} + +void +SVGAngle::SetValue(float aValue, ErrorResult& rv) +{ + if (mType == AnimValue) { + rv.Throw(NS_ERROR_DOM_NO_MODIFICATION_ALLOWED_ERR); + return; + } + bool isBaseVal = mType == BaseValue; + mVal->SetBaseValue(aValue, isBaseVal ? mSVGElement.get() : nullptr, + isBaseVal); +} + +float +SVGAngle::ValueInSpecifiedUnits() const +{ + if (mType == AnimValue) { + return mVal->mAnimVal; + } + return mVal->mBaseVal; +} + +void +SVGAngle::SetValueInSpecifiedUnits(float aValue, ErrorResult& rv) +{ + if (mType == AnimValue) { + rv.Throw(NS_ERROR_DOM_NO_MODIFICATION_ALLOWED_ERR); + return; + } else if (mType == BaseValue) { + mVal->SetBaseValueInSpecifiedUnits(aValue, mSVGElement); + } else { + mVal->mBaseVal = aValue; + } +} + +void +SVGAngle::NewValueSpecifiedUnits(uint16_t unitType, + float valueInSpecifiedUnits, + ErrorResult& rv) +{ + if (mType == AnimValue) { + rv.Throw(NS_ERROR_DOM_NO_MODIFICATION_ALLOWED_ERR); + return; + } + rv = mVal->NewValueSpecifiedUnits(unitType, valueInSpecifiedUnits, + mType == BaseValue ? mSVGElement.get() + : nullptr); +} + +void +SVGAngle::ConvertToSpecifiedUnits(uint16_t unitType, ErrorResult& rv) +{ + if (mType == AnimValue) { + rv.Throw(NS_ERROR_DOM_NO_MODIFICATION_ALLOWED_ERR); + return; + } + rv = mVal->ConvertToSpecifiedUnits(unitType, mType == BaseValue ? + mSVGElement.get() : nullptr); +} + +void +SVGAngle::SetValueAsString(const nsAString& aValue, ErrorResult& rv) +{ + if (mType == AnimValue) { + rv.Throw(NS_ERROR_DOM_NO_MODIFICATION_ALLOWED_ERR); + return; + } + bool isBaseVal = mType == BaseValue; + rv = mVal->SetBaseValueString(aValue, isBaseVal ? mSVGElement.get() : nullptr, + isBaseVal); +} + +void +SVGAngle::GetValueAsString(nsAString& aValue) +{ + if (mType == AnimValue) { + mVal->GetAnimValueString(aValue); + } else { + mVal->GetBaseValueString(aValue); + } +} + |