gecko-dev/dom/svg/DOMSVGAngle.h
longsonr 8e1810987f Bug 1523178 - Merge SVGAngle and nsSVGOrientType into SVGOrient r=jwatt
--HG--
rename : dom/svg/SVGAngle.cpp => dom/svg/SVGOrient.cpp
rename : dom/svg/SVGAngle.h => dom/svg/SVGOrient.h
2019-02-15 08:41:37 +00:00

67 lines
2.1 KiB
C++

/* -*- 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/. */
#ifndef mozilla_dom_SVGAngle_h
#define mozilla_dom_SVGAngle_h
#include "nsWrapperCache.h"
#include "SVGElement.h"
#include "mozilla/Attributes.h"
namespace mozilla {
class SVGOrient;
namespace dom {
class SVGSVGElement;
class DOMSVGAngle final : public nsWrapperCache {
public:
typedef enum { BaseValue, AnimValue, CreatedValue } AngleType;
NS_INLINE_DECL_CYCLE_COLLECTING_NATIVE_REFCOUNTING(DOMSVGAngle)
NS_DECL_CYCLE_COLLECTION_SCRIPT_HOLDER_NATIVE_CLASS(DOMSVGAngle)
/**
* Generic ctor for DOMSVGAngle objects that are created for an attribute.
*/
DOMSVGAngle(SVGOrient* aVal, SVGElement* aSVGElement, AngleType aType)
: mVal(aVal), mSVGElement(aSVGElement), mType(aType) {}
/**
* Ctor for creating the objects returned by SVGSVGElement.createSVGAngle(),
* which do not initially belong to an attribute.
*/
explicit DOMSVGAngle(SVGSVGElement* aSVGElement);
// WebIDL
SVGElement* GetParentObject() { return mSVGElement; }
virtual JSObject* WrapObject(JSContext* aCx,
JS::Handle<JSObject*> aGivenProto) override;
uint16_t UnitType() const;
float Value() const;
void GetValueAsString(nsAString& aValue);
void SetValue(float aValue, ErrorResult& rv);
float ValueInSpecifiedUnits() const;
void SetValueInSpecifiedUnits(float aValue, ErrorResult& rv);
void SetValueAsString(const nsAString& aValue, ErrorResult& rv);
void NewValueSpecifiedUnits(uint16_t unitType, float value, ErrorResult& rv);
void ConvertToSpecifiedUnits(uint16_t unitType, ErrorResult& rv);
protected:
~DOMSVGAngle();
SVGOrient* mVal; // if mType is CreatedValue, we own the angle. Otherwise,
// the element does.
RefPtr<SVGElement> mSVGElement;
AngleType mType;
};
} // namespace dom
} // namespace mozilla
#endif // mozilla_dom_SVGAngle_h