author J.C. Jones <>
Wed, 12 Jun 2019 23:22:22 +0000
changeset 478563 547109ab8d7bb037fa42996e1837f7d231b5d615
parent 471656 1181d18ea08c28012dea5243f24ca38df9d88dab
permissions -rw-r--r--
Bug 1558977 - Upgrade NSS 3.45 r=keeler Differential Revision:

/* -*- 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 */

#ifndef __NS_SVGSTRING_H__
#define __NS_SVGSTRING_H__

#include "DOMSVGAnimatedString.h"
#include "nsAutoPtr.h"
#include "nsError.h"
#include "mozilla/Attributes.h"
#include "mozilla/UniquePtr.h"

namespace mozilla {

class SMILValue;

namespace dom {
class SVGElement;

class SVGAnimatedString {
  typedef mozilla::dom::SVGElement SVGElement;

  void Init(uint8_t aAttrEnum) {
    mAnimVal = nullptr;
    mAttrEnum = aAttrEnum;
    mIsBaseSet = false;

  void SetBaseValue(const nsAString& aValue, SVGElement* aSVGElement,
                    bool aDoSetAttr);
  void GetBaseValue(nsAString& aValue, const SVGElement* aSVGElement) const {
    aSVGElement->GetStringBaseValue(mAttrEnum, aValue);

  void SetAnimValue(const nsAString& aValue, SVGElement* aSVGElement);
  void GetAnimValue(nsAString& aResult, const SVGElement* aSVGElement) const;

  // Returns true if the animated value of this string has been explicitly
  // set (either by animation, or by taking on the base value which has been
  // explicitly set by markup or a DOM call), false otherwise.
  // If this returns false, the animated value is still valid, that is,
  // usable, and represents the default base value of the attribute.
  bool IsExplicitlySet() const { return !!mAnimVal || mIsBaseSet; }

  already_AddRefed<mozilla::dom::DOMSVGAnimatedString> ToDOMAnimatedString(
      SVGElement* aSVGElement);

  mozilla::UniquePtr<SMILAttr> ToSMILAttr(SVGElement* aSVGElement);

  nsAutoPtr<nsString> mAnimVal;
  uint8_t mAttrEnum;  // element specified tracking for attribute
  bool mIsBaseSet;

  // DOM wrapper class for the (DOM)SVGAnimatedString interface where the
  // wrapped class is SVGAnimatedString.
  struct DOMAnimatedString final : public mozilla::dom::DOMSVGAnimatedString {

    DOMAnimatedString(SVGAnimatedString* aVal, SVGElement* aSVGElement)
        : mozilla::dom::DOMSVGAnimatedString(aSVGElement), mVal(aVal) {}

    SVGAnimatedString* mVal;  // kept alive because it belongs to content

    void GetBaseVal(nsAString& aResult) override {
      mVal->GetBaseValue(aResult, mSVGElement);

    void SetBaseVal(const nsAString& aValue) override {
      mVal->SetBaseValue(aValue, mSVGElement, true);

    void GetAnimVal(nsAString& aResult) override {
      mVal->GetAnimValue(aResult, mSVGElement);

    virtual ~DOMAnimatedString();
  struct SMILString : public SMILAttr {
    SMILString(SVGAnimatedString* aVal, SVGElement* aSVGElement)
        : mVal(aVal), mSVGElement(aSVGElement) {}

    // These will stay alive because a SMILAttr only lives as long
    // as the Compositing step, and DOM elements don't get a chance to
    // die during that.
    SVGAnimatedString* mVal;
    SVGElement* mSVGElement;

    // SMILAttr methods
    virtual nsresult ValueFromString(
        const nsAString& aStr,
        const mozilla::dom::SVGAnimationElement* aSrcElement, SMILValue& aValue,
        bool& aPreventCachingOfSandwich) const override;
    virtual SMILValue GetBaseValue() const override;
    virtual void ClearAnimValue() override;
    virtual nsresult SetAnimValue(const SMILValue& aValue) override;

}  // namespace mozilla

#endif  //__NS_SVGSTRING_H__