blob: 7548c8249b4f960d8c77fd6240d7b7f4403b03e2 [file] [log] [blame]
/*
* (C) 1999-2003 Lars Knoll (knoll@kde.org)
* Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved.
* Copyright (C) 2013 Intel Corporation. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#include "third_party/blink/renderer/core/style_property_shorthand.h"
#include "base/stl_util.h"
namespace blink {
const StylePropertyShorthand& animationShorthandForParsing() {
// When we parse the animation shorthand we need to look for animation-name
// last because otherwise it might match against the keywords for fill mode,
// timing functions and infinite iteration. This means that animation names
// that are the same as keywords (e.g. 'forwards') won't always match in the
// shorthand. In that case the authors should be using longhands (or
// reconsidering their approach). This is covered by the animations spec
// bug: https://www.w3.org/Bugs/Public/show_bug.cgi?id=14790
// And in the spec (editor's draft) at:
// https://drafts.csswg.org/css-animations/#animation-shorthand-property
static const CSSProperty* kAnimationPropertiesForParsing[] = {
&GetCSSPropertyAnimationDuration(),
&GetCSSPropertyAnimationTimingFunction(),
&GetCSSPropertyAnimationDelay(),
&GetCSSPropertyAnimationIterationCount(),
&GetCSSPropertyAnimationDirection(),
&GetCSSPropertyAnimationFillMode(),
&GetCSSPropertyAnimationPlayState(),
&GetCSSPropertyAnimationName()};
static StylePropertyShorthand webkit_animation_longhands_for_parsing(
CSSPropertyAnimation, kAnimationPropertiesForParsing,
base::size(kAnimationPropertiesForParsing));
return webkit_animation_longhands_for_parsing;
}
// Similar to animations, we have property after timing-function and delay after
// duration
const StylePropertyShorthand& transitionShorthandForParsing() {
static const CSSProperty* kTransitionProperties[] = {
&GetCSSPropertyTransitionDuration(),
&GetCSSPropertyTransitionTimingFunction(),
&GetCSSPropertyTransitionDelay(), &GetCSSPropertyTransitionProperty()};
static StylePropertyShorthand transition_longhands(
CSSPropertyTransition, kTransitionProperties,
base::size(kTransitionProperties));
return transition_longhands;
}
unsigned indexOfShorthandForLonghand(
CSSPropertyID shorthand_id,
const Vector<StylePropertyShorthand, 4>& shorthands) {
for (unsigned i = 0; i < shorthands.size(); ++i) {
if (shorthands.at(i).id() == shorthand_id)
return i;
}
NOTREACHED();
return 0;
}
} // namespace blink