| /* |
| * Copyright (C) 2014 Google Inc. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions are |
| * met: |
| * |
| * * Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * * Redistributions in binary form must reproduce the above |
| * copyright notice, this list of conditions and the following disclaimer |
| * in the documentation and/or other materials provided with the |
| * distribution. |
| * * Neither the name of Google Inc. nor the names of its |
| * contributors may be used to endorse or promote products derived from |
| * this software without specific prior written permission. |
| * |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #include "third_party/blink/renderer/core/svg/svg_integer_optional_integer.h" |
| |
| #include "third_party/blink/renderer/core/svg/svg_parser_utilities.h" |
| #include "third_party/blink/renderer/platform/heap/heap.h" |
| |
| namespace blink { |
| |
| SVGIntegerOptionalInteger::SVGIntegerOptionalInteger(SVGInteger* first_integer, |
| SVGInteger* second_integer) |
| : first_integer_(first_integer), second_integer_(second_integer) {} |
| |
| void SVGIntegerOptionalInteger::Trace(Visitor* visitor) const { |
| visitor->Trace(first_integer_); |
| visitor->Trace(second_integer_); |
| SVGPropertyBase::Trace(visitor); |
| } |
| |
| SVGIntegerOptionalInteger* SVGIntegerOptionalInteger::Clone() const { |
| return MakeGarbageCollected<SVGIntegerOptionalInteger>( |
| first_integer_->Clone(), second_integer_->Clone()); |
| } |
| |
| SVGPropertyBase* SVGIntegerOptionalInteger::CloneForAnimation( |
| const String& value) const { |
| auto* clone = MakeGarbageCollected<SVGIntegerOptionalInteger>( |
| MakeGarbageCollected<SVGInteger>(0), MakeGarbageCollected<SVGInteger>(0)); |
| clone->SetValueAsString(value); |
| return clone; |
| } |
| |
| String SVGIntegerOptionalInteger::ValueAsString() const { |
| if (first_integer_->Value() == second_integer_->Value()) { |
| return String::Number(first_integer_->Value()); |
| } |
| |
| return String::Number(first_integer_->Value()) + " " + |
| String::Number(second_integer_->Value()); |
| } |
| |
| SVGParsingError SVGIntegerOptionalInteger::SetValueAsString( |
| const String& value) { |
| float x, y; |
| SVGParsingError parse_status; |
| if (!ParseNumberOptionalNumber(value, x, y)) { |
| parse_status = SVGParseStatus::kExpectedInteger; |
| x = y = 0; |
| } |
| |
| first_integer_->SetValue(clampTo<int>(x)); |
| second_integer_->SetValue(clampTo<int>(y)); |
| return parse_status; |
| } |
| |
| void SVGIntegerOptionalInteger::SetInitial(unsigned value) { |
| // Propagate the value to the split representation. |
| first_integer_->SetInitial(value); |
| second_integer_->SetInitial(value); |
| } |
| |
| void SVGIntegerOptionalInteger::Add(const SVGPropertyBase* other, |
| const SVGElement* context_element) { |
| auto* other_integer_optional_integer = To<SVGIntegerOptionalInteger>(other); |
| first_integer_->Add(other_integer_optional_integer->FirstInteger(), |
| context_element); |
| second_integer_->Add(other_integer_optional_integer->SecondInteger(), |
| context_element); |
| } |
| |
| void SVGIntegerOptionalInteger::CalculateAnimatedValue( |
| const SMILAnimationEffectParameters& parameters, |
| float percentage, |
| unsigned repeat_count, |
| const SVGPropertyBase* from, |
| const SVGPropertyBase* to, |
| const SVGPropertyBase* to_at_end_of_duration, |
| const SVGElement* context_element) { |
| auto* from_integer = To<SVGIntegerOptionalInteger>(from); |
| auto* to_integer = To<SVGIntegerOptionalInteger>(to); |
| auto* to_at_end_of_duration_integer = |
| To<SVGIntegerOptionalInteger>(to_at_end_of_duration); |
| |
| first_integer_->CalculateAnimatedValue( |
| parameters, percentage, repeat_count, from_integer->FirstInteger(), |
| to_integer->FirstInteger(), to_at_end_of_duration_integer->FirstInteger(), |
| context_element); |
| second_integer_->CalculateAnimatedValue( |
| parameters, percentage, repeat_count, from_integer->SecondInteger(), |
| to_integer->SecondInteger(), |
| to_at_end_of_duration_integer->SecondInteger(), context_element); |
| } |
| |
| float SVGIntegerOptionalInteger::CalculateDistance(const SVGPropertyBase* other, |
| const SVGElement*) const { |
| // FIXME: Distance calculation is not possible for SVGIntegerOptionalInteger |
| // right now. We need the distance for every single value. |
| return -1; |
| } |
| |
| } // namespace blink |