| /* |
| * Copyright (C) 2000 Lars Knoll (knoll@kde.org) |
| * (C) 2000 Antti Koivisto (koivisto@kde.org) |
| * (C) 2000 Dirk Mueller (mueller@kde.org) |
| * Copyright (C) 2003, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved. |
| * Copyright (C) 2006 Graham Dennis (graham.dennis@gmail.com) |
| * |
| * 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. |
| * |
| */ |
| |
| #ifndef RenderStyle_h |
| #define RenderStyle_h |
| |
| /* |
| * WARNING: |
| * -------- |
| * |
| * The order of the values in the enums have to agree with the order specified |
| * in CSSValueKeywords.in, otherwise some optimizations in the parser will fail, |
| * and produce invaliud results. |
| */ |
| |
| #include "AffineTransform.h" |
| #include "CSSHelper.h" |
| #include "CSSPrimitiveValue.h" |
| #include "CSSValueList.h" |
| #include "Color.h" |
| #include "CSSCursorImageValue.h" |
| #include "CSSTransformValue.h" |
| #include "DataRef.h" |
| #include "Font.h" |
| #include "FloatPoint.h" |
| #include "GraphicsTypes.h" |
| #include "IntRect.h" |
| #include "Length.h" |
| #include "Pair.h" |
| #include <wtf/RefCounted.h> |
| #include "TextDirection.h" |
| #include <wtf/HashMap.h> |
| #include <wtf/Vector.h> |
| |
| #if ENABLE(SVG) |
| #include "SVGRenderStyle.h" |
| #endif |
| |
| template<typename T, typename U> inline bool compareEqual(const T& t, const U& u) { return t == static_cast<T>(u); } |
| |
| #define SET_VAR(group, variable, value) \ |
| if (!compareEqual(group->variable, value)) \ |
| group.access()->variable = value; |
| |
| namespace WebCore { |
| |
| using std::max; |
| |
| class CSSStyleSelector; |
| class CSSValueList; |
| class CachedImage; |
| class CachedResource; |
| class CursorList; |
| class Pair; |
| class RenderArena; |
| class ShadowValue; |
| class StringImpl; |
| |
| struct CursorData; |
| |
| enum PseudoState { PseudoUnknown, PseudoNone, PseudoAnyLink, PseudoLink, PseudoVisited}; |
| |
| //------------------------------------------------ |
| |
| //------------------------------------------------ |
| // Box model attributes. Not inherited. |
| |
| struct LengthBox { |
| LengthBox() { } |
| LengthBox(LengthType t) |
| : left(t), right(t), top(t), bottom(t) { } |
| |
| Length left; |
| Length right; |
| Length top; |
| Length bottom; |
| |
| LengthBox& operator=(const Length& len) |
| { |
| left = len; |
| right = len; |
| top = len; |
| bottom = len; |
| return *this; |
| } |
| |
| bool operator==(const LengthBox& o) const |
| { |
| return left == o.left && right == o.right && top == o.top && bottom == o.bottom; |
| } |
| |
| bool operator!=(const LengthBox& o) const |
| { |
| return !(*this == o); |
| } |
| |
| bool nonZero() const { return !(left.isZero() && right.isZero() && top.isZero() && bottom.isZero()); } |
| }; |
| |
| enum EPosition { |
| StaticPosition, RelativePosition, AbsolutePosition, FixedPosition |
| }; |
| |
| enum EFloat { |
| FNONE = 0, FLEFT, FRIGHT |
| }; |
| |
| //------------------------------------------------ |
| // Border attributes. Not inherited. |
| |
| // These have been defined in the order of their precedence for border-collapsing. Do |
| // not change this order! |
| enum EBorderStyle { |
| BNONE, BHIDDEN, INSET, GROOVE, RIDGE, OUTSET, DOTTED, DASHED, SOLID, DOUBLE |
| }; |
| |
| class BorderValue { |
| public: |
| BorderValue() { |
| width = 3; // medium is default value |
| m_style = BNONE; |
| } |
| |
| Color color; |
| unsigned width : 12; |
| unsigned m_style : 4; // EBorderStyle |
| |
| EBorderStyle style() const { return static_cast<EBorderStyle>(m_style); } |
| |
| bool nonZero(bool checkStyle = true) const { |
| return width != 0 && (!checkStyle || m_style != BNONE); |
| } |
| |
| bool isTransparent() const { |
| return color.isValid() && color.alpha() == 0; |
| } |
| |
| bool isVisible(bool checkStyle = true) const { |
| return nonZero(checkStyle) && !isTransparent() && (!checkStyle || m_style != BHIDDEN); |
| } |
| |
| bool operator==(const BorderValue& o) const |
| { |
| return width == o.width && m_style == o.m_style && color == o.color; |
| } |
| |
| bool operator!=(const BorderValue& o) const |
| { |
| return !(*this == o); |
| } |
| }; |
| |
| class OutlineValue : public BorderValue { |
| public: |
| OutlineValue() |
| { |
| _offset = 0; |
| _auto = false; |
| } |
| |
| bool operator==(const OutlineValue& o) const |
| { |
| return width == o.width && m_style == o.m_style && color == o.color && _offset == o._offset && _auto == o._auto; |
| } |
| |
| bool operator!=(const OutlineValue& o) const |
| { |
| return !(*this == o); |
| } |
| |
| int _offset; |
| bool _auto; |
| }; |
| |
| enum EBorderPrecedence { BOFF, BTABLE, BCOLGROUP, BCOL, BROWGROUP, BROW, BCELL }; |
| |
| struct CollapsedBorderValue { |
| CollapsedBorderValue() : border(0), precedence(BOFF) {} |
| CollapsedBorderValue(const BorderValue* b, EBorderPrecedence p) :border(b), precedence(p) {} |
| |
| int width() const { return border && border->nonZero() ? border->width : 0; } |
| EBorderStyle style() const { return border ? border->style() : BHIDDEN; } |
| bool exists() const { return border; } |
| Color color() const { return border ? border->color : Color(); } |
| bool isTransparent() const { return border ? border->isTransparent() : true; } |
| |
| bool operator==(const CollapsedBorderValue& o) const |
| { |
| if (!border) return !o.border; |
| if (!o.border) return false; |
| return *border == *o.border && precedence == o.precedence; |
| } |
| |
| const BorderValue* border; |
| EBorderPrecedence precedence; |
| }; |
| |
| enum EBorderImageRule { |
| BI_STRETCH, BI_ROUND, BI_REPEAT |
| }; |
| |
| class BorderImage { |
| public: |
| BorderImage() :m_image(0), m_horizontalRule(BI_STRETCH), m_verticalRule(BI_STRETCH) {} |
| BorderImage(CachedImage* image, LengthBox slices, EBorderImageRule h, EBorderImageRule v) |
| :m_image(image), m_slices(slices), m_horizontalRule(h), m_verticalRule(v) {} |
| |
| bool operator==(const BorderImage& o) const |
| { |
| return m_image == o.m_image && m_slices == o.m_slices && m_horizontalRule == o.m_horizontalRule && |
| m_verticalRule == o.m_verticalRule; |
| } |
| |
| bool hasImage() const { return m_image != 0; } |
| CachedImage* image() const { return m_image; } |
| |
| EBorderImageRule horizontalRule() const { return static_cast<EBorderImageRule>(m_horizontalRule); } |
| EBorderImageRule verticalRule() const { return static_cast<EBorderImageRule>(m_verticalRule); } |
| |
| CachedImage* m_image; |
| LengthBox m_slices; |
| unsigned m_horizontalRule : 2; // EBorderImageRule |
| unsigned m_verticalRule : 2; // EBorderImageRule |
| }; |
| |
| class BorderData { |
| public: |
| BorderValue left; |
| BorderValue right; |
| BorderValue top; |
| BorderValue bottom; |
| |
| BorderImage image; |
| |
| IntSize topLeft; |
| IntSize topRight; |
| IntSize bottomLeft; |
| IntSize bottomRight; |
| |
| bool hasBorder() const |
| { |
| bool haveImage = image.hasImage(); |
| return left.nonZero(!haveImage) || right.nonZero(!haveImage) || top.nonZero(!haveImage) || bottom.nonZero(!haveImage); |
| } |
| |
| bool hasBorderRadius() const { |
| if (topLeft.width() > 0) |
| return true; |
| if (topRight.width() > 0) |
| return true; |
| if (bottomLeft.width() > 0) |
| return true; |
| if (bottomRight.width() > 0) |
| return true; |
| return false; |
| } |
| |
| unsigned short borderLeftWidth() const { |
| if (!image.hasImage() && (left.style() == BNONE || left.style() == BHIDDEN)) |
| return 0; |
| return left.width; |
| } |
| |
| unsigned short borderRightWidth() const { |
| if (!image.hasImage() && (right.style() == BNONE || right.style() == BHIDDEN)) |
| return 0; |
| return right.width; |
| } |
| |
| unsigned short borderTopWidth() const { |
| if (!image.hasImage() && (top.style() == BNONE || top.style() == BHIDDEN)) |
| return 0; |
| return top.width; |
| } |
| |
| unsigned short borderBottomWidth() const { |
| if (!image.hasImage() && (bottom.style() == BNONE || bottom.style() == BHIDDEN)) |
| return 0; |
| return bottom.width; |
| } |
| |
| bool operator==(const BorderData& o) const |
| { |
| return left == o.left && right == o.right && top == o.top && bottom == o.bottom && image == o.image && |
| topLeft == o.topLeft && topRight == o.topRight && bottomLeft == o.bottomLeft && bottomRight == o.bottomRight; |
| } |
| |
| bool operator!=(const BorderData& o) const { |
| return !(*this == o); |
| } |
| }; |
| |
| enum EMarginCollapse { MCOLLAPSE, MSEPARATE, MDISCARD }; |
| |
| class StyleSurroundData : public RefCounted<StyleSurroundData> { |
| public: |
| StyleSurroundData(); |
| StyleSurroundData(const StyleSurroundData& o); |
| |
| bool operator==(const StyleSurroundData& o) const; |
| bool operator!=(const StyleSurroundData& o) const { |
| return !(*this == o); |
| } |
| |
| LengthBox offset; |
| LengthBox margin; |
| LengthBox padding; |
| BorderData border; |
| }; |
| |
| |
| //------------------------------------------------ |
| // Box attributes. Not inherited. |
| |
| enum EBoxSizing { CONTENT_BOX, BORDER_BOX }; |
| |
| class StyleBoxData : public RefCounted<StyleBoxData> { |
| public: |
| StyleBoxData(); |
| StyleBoxData(const StyleBoxData& o); |
| |
| // copy and assignment |
| // StyleBoxData(const StyleBoxData &other); |
| // const StyleBoxData &operator = (const StyleBoxData &other); |
| |
| bool operator==(const StyleBoxData& o) const; |
| bool operator!=(const StyleBoxData& o) const { |
| return !(*this == o); |
| } |
| |
| Length width; |
| Length height; |
| |
| Length min_width; |
| Length max_width; |
| |
| Length min_height; |
| Length max_height; |
| |
| Length vertical_align; |
| |
| int z_index; |
| bool z_auto : 1; |
| unsigned boxSizing : 1; // EBoxSizing |
| }; |
| |
| //------------------------------------------------ |
| // Dashboard region attributes. Not inherited. |
| |
| struct StyleDashboardRegion { |
| String label; |
| LengthBox offset; |
| int type; |
| |
| enum { |
| None, |
| Circle, |
| Rectangle |
| }; |
| |
| bool operator==(const StyleDashboardRegion& o) const |
| { |
| return type == o.type && offset == o.offset && label == o.label; |
| } |
| |
| bool operator!=(const StyleDashboardRegion& o) const |
| { |
| return !(*this == o); |
| } |
| }; |
| |
| //------------------------------------------------ |
| // Random visual rendering model attributes. Not inherited. |
| |
| enum EOverflow { |
| OVISIBLE, OHIDDEN, OSCROLL, OAUTO, OOVERLAY, OMARQUEE |
| }; |
| |
| enum EVerticalAlign { |
| BASELINE, MIDDLE, SUB, SUPER, TEXT_TOP, |
| TEXT_BOTTOM, TOP, BOTTOM, BASELINE_MIDDLE, LENGTH |
| }; |
| |
| enum EClear{ |
| CNONE = 0, CLEFT = 1, CRIGHT = 2, CBOTH = 3 |
| }; |
| |
| enum ETableLayout { |
| TAUTO, TFIXED |
| }; |
| |
| enum EUnicodeBidi { |
| UBNormal, Embed, Override |
| }; |
| |
| class StyleVisualData : public RefCounted<StyleVisualData> { |
| public: |
| StyleVisualData(); |
| ~StyleVisualData(); |
| StyleVisualData(const StyleVisualData&); |
| |
| bool operator==(const StyleVisualData& o) const { |
| return ( clip == o.clip && |
| hasClip == o.hasClip && |
| counterIncrement == o.counterIncrement && |
| counterReset == o.counterReset && |
| textDecoration == o.textDecoration); |
| } |
| bool operator!=(const StyleVisualData& o) const { return !(*this == o); } |
| |
| LengthBox clip; |
| bool hasClip : 1; |
| unsigned textDecoration : 4; // Text decorations defined *only* by this element. |
| |
| short counterIncrement; // ok, so these are not visual mode specific |
| short counterReset; // can't go to inherited, since these are not inherited |
| |
| }; |
| |
| //------------------------------------------------ |
| enum EBackgroundBox { |
| BGBORDER, BGPADDING, BGCONTENT |
| }; |
| |
| enum EBackgroundRepeat { |
| REPEAT, REPEAT_X, REPEAT_Y, NO_REPEAT |
| }; |
| |
| struct LengthSize { |
| Length width; |
| Length height; |
| }; |
| |
| struct BackgroundLayer { |
| public: |
| BackgroundLayer(); |
| ~BackgroundLayer(); |
| |
| CachedImage* backgroundImage() const { return m_image; } |
| Length backgroundXPosition() const { return m_xPosition; } |
| Length backgroundYPosition() const { return m_yPosition; } |
| bool backgroundAttachment() const { return m_bgAttachment; } |
| EBackgroundBox backgroundClip() const { return static_cast<EBackgroundBox>(m_bgClip); } |
| EBackgroundBox backgroundOrigin() const { return static_cast<EBackgroundBox>(m_bgOrigin); } |
| EBackgroundRepeat backgroundRepeat() const { return static_cast<EBackgroundRepeat>(m_bgRepeat); } |
| CompositeOperator backgroundComposite() const { return static_cast<CompositeOperator>(m_bgComposite); } |
| LengthSize backgroundSize() const { return m_backgroundSize; } |
| |
| const BackgroundLayer* next() const { return m_next; } |
| BackgroundLayer* next() { return m_next; } |
| |
| bool isBackgroundImageSet() const { return m_imageSet; } |
| bool isBackgroundXPositionSet() const { return m_xPosSet; } |
| bool isBackgroundYPositionSet() const { return m_yPosSet; } |
| bool isBackgroundAttachmentSet() const { return m_attachmentSet; } |
| bool isBackgroundClipSet() const { return m_clipSet; } |
| bool isBackgroundOriginSet() const { return m_originSet; } |
| bool isBackgroundRepeatSet() const { return m_repeatSet; } |
| bool isBackgroundCompositeSet() const { return m_compositeSet; } |
| bool isBackgroundSizeSet() const { return m_backgroundSizeSet; } |
| |
| void setBackgroundImage(CachedImage* i) { m_image = i; m_imageSet = true; } |
| void setBackgroundXPosition(const Length& l) { m_xPosition = l; m_xPosSet = true; } |
| void setBackgroundYPosition(const Length& l) { m_yPosition = l; m_yPosSet = true; } |
| void setBackgroundAttachment(bool b) { m_bgAttachment = b; m_attachmentSet = true; } |
| void setBackgroundClip(EBackgroundBox b) { m_bgClip = b; m_clipSet = true; } |
| void setBackgroundOrigin(EBackgroundBox b) { m_bgOrigin = b; m_originSet = true; } |
| void setBackgroundRepeat(EBackgroundRepeat r) { m_bgRepeat = r; m_repeatSet = true; } |
| void setBackgroundComposite(CompositeOperator c) { m_bgComposite = c; m_compositeSet = true; } |
| void setBackgroundSize(const LengthSize& b) { m_backgroundSize = b; m_backgroundSizeSet = true; } |
| |
| void clearBackgroundImage() { m_imageSet = false; } |
| void clearBackgroundXPosition() { m_xPosSet = false; } |
| void clearBackgroundYPosition() { m_yPosSet = false; } |
| void clearBackgroundAttachment() { m_attachmentSet = false; } |
| void clearBackgroundClip() { m_clipSet = false; } |
| void clearBackgroundOrigin() { m_originSet = false; } |
| void clearBackgroundRepeat() { m_repeatSet = false; } |
| void clearBackgroundComposite() { m_compositeSet = false; } |
| void clearBackgroundSize() { m_backgroundSizeSet = false; } |
| |
| void setNext(BackgroundLayer* n) { if (m_next != n) { delete m_next; m_next = n; } } |
| |
| BackgroundLayer& operator=(const BackgroundLayer& o); |
| BackgroundLayer(const BackgroundLayer& o); |
| |
| bool operator==(const BackgroundLayer& o) const; |
| bool operator!=(const BackgroundLayer& o) const { |
| return !(*this == o); |
| } |
| |
| bool containsImage(CachedImage* c) const { if (c == m_image) return true; if (m_next) return m_next->containsImage(c); return false; } |
| |
| bool hasImage() const { |
| if (m_image) |
| return true; |
| return m_next ? m_next->hasImage() : false; |
| } |
| bool hasFixedImage() const { |
| if (m_image && !m_bgAttachment) |
| return true; |
| return m_next ? m_next->hasFixedImage() : false; |
| } |
| |
| void fillUnsetProperties(); |
| void cullEmptyLayers(); |
| |
| CachedImage* m_image; |
| |
| Length m_xPosition; |
| Length m_yPosition; |
| |
| bool m_bgAttachment : 1; |
| unsigned m_bgClip : 2; // EBackgroundBox |
| unsigned m_bgOrigin : 2; // EBackgroundBox |
| unsigned m_bgRepeat : 2; // EBackgroundRepeat |
| unsigned m_bgComposite : 2; // CompositeOperator |
| |
| LengthSize m_backgroundSize; |
| |
| bool m_imageSet : 1; |
| bool m_attachmentSet : 1; |
| bool m_clipSet : 1; |
| bool m_originSet : 1; |
| bool m_repeatSet : 1; |
| bool m_xPosSet : 1; |
| bool m_yPosSet : 1; |
| bool m_compositeSet : 1; |
| bool m_backgroundSizeSet : 1; |
| |
| BackgroundLayer* m_next; |
| }; |
| |
| class StyleBackgroundData : public RefCounted<StyleBackgroundData> { |
| public: |
| StyleBackgroundData(); |
| ~StyleBackgroundData() {} |
| StyleBackgroundData(const StyleBackgroundData& o ); |
| |
| bool operator==(const StyleBackgroundData& o) const; |
| bool operator!=(const StyleBackgroundData &o) const { |
| return !(*this == o); |
| } |
| |
| BackgroundLayer m_background; |
| Color m_color; |
| OutlineValue m_outline; |
| }; |
| |
| //------------------------------------------------ |
| // CSS3 Marquee Properties |
| |
| enum EMarqueeBehavior { MNONE, MSCROLL, MSLIDE, MALTERNATE }; |
| enum EMarqueeDirection { MAUTO = 0, MLEFT = 1, MRIGHT = -1, MUP = 2, MDOWN = -2, MFORWARD = 3, MBACKWARD = -3 }; |
| |
| class StyleMarqueeData : public RefCounted<StyleMarqueeData> { |
| public: |
| StyleMarqueeData(); |
| StyleMarqueeData(const StyleMarqueeData& o); |
| |
| bool operator==(const StyleMarqueeData& o) const; |
| bool operator!=(const StyleMarqueeData& o) const { |
| return !(*this == o); |
| } |
| |
| Length increment; |
| int speed; |
| |
| int loops; // -1 means infinite. |
| |
| unsigned behavior : 3; // EMarqueeBehavior |
| EMarqueeDirection direction : 3; // not unsigned because EMarqueeDirection has negative values |
| }; |
| |
| // CSS3 Multi Column Layout |
| |
| class StyleMultiColData : public RefCounted<StyleMultiColData> { |
| public: |
| StyleMultiColData(); |
| StyleMultiColData(const StyleMultiColData& o); |
| |
| bool operator==(const StyleMultiColData& o) const; |
| bool operator!=(const StyleMultiColData &o) const { |
| return !(*this == o); |
| } |
| |
| unsigned short ruleWidth() const { |
| if (m_rule.style() == BNONE || m_rule.style() == BHIDDEN) |
| return 0; |
| return m_rule.width; |
| } |
| |
| float m_width; |
| unsigned short m_count; |
| float m_gap; |
| BorderValue m_rule; |
| |
| bool m_autoWidth : 1; |
| bool m_autoCount : 1; |
| bool m_normalGap : 1; |
| unsigned m_breakBefore : 2; // EPageBreak |
| unsigned m_breakAfter : 2; // EPageBreak |
| unsigned m_breakInside : 2; // EPageBreak |
| }; |
| |
| // CSS Transforms (may become part of CSS3) |
| |
| class TransformOperation : public RefCounted<TransformOperation> |
| { |
| public: |
| virtual ~TransformOperation() {} |
| |
| virtual bool operator==(const TransformOperation&) const = 0; |
| bool operator!=(const TransformOperation& o) const { return !(*this == o); } |
| |
| virtual void apply(AffineTransform&, const IntSize& borderBoxSize) = 0; |
| |
| virtual TransformOperation* blend(const TransformOperation* from, double progress, bool blendToIdentity = false) = 0; |
| |
| virtual bool isScaleOperation() const { return false; } |
| virtual bool isRotateOperation() const { return false; } |
| virtual bool isSkewOperation() const { return false; } |
| virtual bool isTranslateOperation() const { return false; } |
| virtual bool isMatrixOperation() const { return false; } |
| }; |
| |
| class ScaleTransformOperation : public TransformOperation |
| { |
| public: |
| ScaleTransformOperation(double sx, double sy) |
| : m_x(sx), m_y(sy) |
| {} |
| |
| virtual bool isScaleOperation() const { return true; } |
| |
| virtual bool operator==(const TransformOperation& o) const |
| { |
| if (o.isScaleOperation()) { |
| const ScaleTransformOperation* s = static_cast<const ScaleTransformOperation*>(&o); |
| return m_x == s->m_x && m_y == s->m_y; |
| } |
| return false; |
| } |
| |
| virtual void apply(AffineTransform& transform, const IntSize& borderBoxSize) |
| { |
| transform.scale(m_x, m_y); |
| } |
| |
| virtual TransformOperation* blend(const TransformOperation* from, double progress, bool blendToIdentity = false); |
| |
| private: |
| double m_x; |
| double m_y; |
| }; |
| |
| class RotateTransformOperation : public TransformOperation |
| { |
| public: |
| RotateTransformOperation(double angle) |
| : m_angle(angle) |
| {} |
| |
| virtual bool isRotateOperation() const { return true; } |
| |
| virtual bool operator==(const TransformOperation& o) const |
| { |
| if (o.isRotateOperation()) { |
| const RotateTransformOperation* r = static_cast<const RotateTransformOperation*>(&o); |
| return m_angle == r->m_angle; |
| } |
| return false; |
| } |
| |
| virtual void apply(AffineTransform& transform, const IntSize& borderBoxSize) |
| { |
| transform.rotate(m_angle); |
| } |
| |
| virtual TransformOperation* blend(const TransformOperation* from, double progress, bool blendToIdentity = false); |
| |
| private: |
| double m_angle; |
| }; |
| |
| class SkewTransformOperation : public TransformOperation |
| { |
| public: |
| SkewTransformOperation(double angleX, double angleY) |
| : m_angleX(angleX), m_angleY(angleY) |
| {} |
| |
| virtual bool isSkewOperation() const { return true; } |
| |
| virtual bool operator==(const TransformOperation& o) const |
| { |
| if (o.isSkewOperation()) { |
| const SkewTransformOperation* s = static_cast<const SkewTransformOperation*>(&o); |
| return m_angleX == s->m_angleX && m_angleY == s->m_angleY; |
| } |
| return false; |
| } |
| |
| virtual void apply(AffineTransform& transform, const IntSize& borderBoxSize) |
| { |
| transform.skew(m_angleX, m_angleY); |
| } |
| |
| virtual TransformOperation* blend(const TransformOperation* from, double progress, bool blendToIdentity = false); |
| |
| private: |
| double m_angleX; |
| double m_angleY; |
| }; |
| |
| class TranslateTransformOperation : public TransformOperation |
| { |
| public: |
| TranslateTransformOperation(const Length& tx, const Length& ty) |
| : m_x(tx), m_y(ty) |
| {} |
| |
| virtual bool isTranslateOperation() const { return true; } |
| |
| virtual bool operator==(const TransformOperation& o) const |
| { |
| if (o.isTranslateOperation()) { |
| const TranslateTransformOperation* t = static_cast<const TranslateTransformOperation*>(&o); |
| return m_x == t->m_x && m_y == t->m_y; |
| } |
| return false; |
| } |
| |
| virtual void apply(AffineTransform& transform, const IntSize& borderBoxSize) |
| { |
| transform.translate(m_x.calcValue(borderBoxSize.width()), m_y.calcValue(borderBoxSize.height())); |
| } |
| |
| virtual TransformOperation* blend(const TransformOperation* from, double progress, bool blendToIdentity = false); |
| |
| private: |
| Length m_x; |
| Length m_y; |
| }; |
| |
| class MatrixTransformOperation : public TransformOperation |
| { |
| public: |
| MatrixTransformOperation(double a, double b, double c, double d, double e, double f) |
| : m_a(a), m_b(b), m_c(c), m_d(d), m_e(e), m_f(f) |
| {} |
| |
| virtual bool isMatrixOperation() const { return true; } |
| |
| virtual bool operator==(const TransformOperation& o) const |
| { |
| if (o.isMatrixOperation()) { |
| const MatrixTransformOperation* m = static_cast<const MatrixTransformOperation*>(&o); |
| return m_a == m->m_a && m_b == m->m_b && m_c == m->m_c && m_d == m->m_d && m_e == m->m_e && m_f == m->m_f; |
| } |
| return false; |
| } |
| |
| virtual void apply(AffineTransform& transform, const IntSize& borderBoxSize) |
| { |
| AffineTransform matrix(m_a, m_b, m_c, m_d, m_e, m_f); |
| transform = matrix * transform; |
| } |
| |
| virtual TransformOperation* blend(const TransformOperation* from, double progress, bool blendToIdentity = false); |
| |
| private: |
| double m_a; |
| double m_b; |
| double m_c; |
| double m_d; |
| double m_e; |
| double m_f; |
| }; |
| |
| class TransformOperations |
| { |
| public: |
| bool operator==(const TransformOperations&) const; |
| bool operator!=(const TransformOperations& o) const { |
| return !(*this == o); |
| } |
| |
| bool isEmpty() const { return m_operations.isEmpty(); } |
| unsigned size() const { return m_operations.size(); } |
| const RefPtr<TransformOperation>& operator[](size_t i) const { return m_operations.at(i); } |
| |
| void append(const RefPtr<TransformOperation>& op) { return m_operations.append(op); } |
| |
| private: |
| Vector<RefPtr<TransformOperation> > m_operations; |
| }; |
| |
| class StyleTransformData : public RefCounted<StyleTransformData> { |
| public: |
| StyleTransformData(); |
| StyleTransformData(const StyleTransformData&); |
| |
| bool operator==(const StyleTransformData&) const; |
| bool operator!=(const StyleTransformData& o) const { |
| return !(*this == o); |
| } |
| |
| TransformOperations m_operations; |
| Length m_x; |
| Length m_y; |
| }; |
| |
| //------------------------------------------------ |
| // CSS3 Flexible Box Properties |
| |
| enum EBoxAlignment { BSTRETCH, BSTART, BCENTER, BEND, BJUSTIFY, BBASELINE }; |
| enum EBoxOrient { HORIZONTAL, VERTICAL }; |
| enum EBoxLines { SINGLE, MULTIPLE }; |
| enum EBoxDirection { BNORMAL, BREVERSE }; |
| |
| class StyleFlexibleBoxData : public RefCounted<StyleFlexibleBoxData> { |
| public: |
| StyleFlexibleBoxData(); |
| StyleFlexibleBoxData(const StyleFlexibleBoxData& o); |
| |
| bool operator==(const StyleFlexibleBoxData& o) const; |
| bool operator!=(const StyleFlexibleBoxData &o) const { |
| return !(*this == o); |
| } |
| |
| float flex; |
| unsigned int flex_group; |
| unsigned int ordinal_group; |
| |
| unsigned align : 3; // EBoxAlignment |
| unsigned pack: 3; // EBoxAlignment |
| unsigned orient: 1; // EBoxOrient |
| unsigned lines : 1; // EBoxLines |
| }; |
| |
| // This struct holds information about shadows for the text-shadow and box-shadow properties. |
| struct ShadowData { |
| ShadowData(int _x, int _y, int _blur, const Color& _color) |
| :x(_x), y(_y), blur(_blur), color(_color), next(0) {} |
| ShadowData(const ShadowData& o); |
| |
| ~ShadowData() { delete next; } |
| |
| bool operator==(const ShadowData& o) const; |
| bool operator!=(const ShadowData &o) const { |
| return !(*this == o); |
| } |
| |
| int x; |
| int y; |
| int blur; |
| Color color; |
| ShadowData* next; |
| }; |
| |
| #if ENABLE(XBL) |
| struct BindingURI { |
| BindingURI(StringImpl*); |
| ~BindingURI(); |
| |
| BindingURI* copy(); |
| |
| bool operator==(const BindingURI& o) const; |
| bool operator!=(const BindingURI& o) const { |
| return !(*this == o); |
| } |
| |
| BindingURI* next() { return m_next; } |
| void setNext(BindingURI* n) { m_next = n; } |
| |
| StringImpl* uri() { return m_uri; } |
| |
| BindingURI* m_next; |
| StringImpl* m_uri; |
| }; |
| #endif |
| |
| //------------------------------------------------ |
| |
| enum ETextSecurity { |
| TSNONE, TSDISC, TSCIRCLE, TSSQUARE |
| }; |
| |
| // CSS3 User Modify Properties |
| |
| enum EUserModify { |
| READ_ONLY, READ_WRITE, READ_WRITE_PLAINTEXT_ONLY |
| }; |
| |
| // CSS3 User Drag Values |
| |
| enum EUserDrag { |
| DRAG_AUTO, DRAG_NONE, DRAG_ELEMENT |
| }; |
| |
| // CSS3 User Select Values |
| |
| enum EUserSelect { |
| SELECT_NONE, SELECT_TEXT |
| }; |
| |
| // Word Break Values. Matches WinIE, rather than CSS3 |
| |
| enum EWordBreak { |
| NormalWordBreak, BreakAllWordBreak, BreakWordBreak |
| }; |
| |
| enum EWordWrap { |
| NormalWordWrap, BreakWordWrap |
| }; |
| |
| enum ENBSPMode { |
| NBNORMAL, SPACE |
| }; |
| |
| enum EKHTMLLineBreak { |
| LBNORMAL, AFTER_WHITE_SPACE |
| }; |
| |
| enum EMatchNearestMailBlockquoteColor { |
| BCNORMAL, MATCH |
| }; |
| |
| enum EResize { |
| RESIZE_NONE, RESIZE_BOTH, RESIZE_HORIZONTAL, RESIZE_VERTICAL |
| }; |
| |
| enum EAppearance { |
| NoAppearance, CheckboxAppearance, RadioAppearance, PushButtonAppearance, SquareButtonAppearance, ButtonAppearance, |
| ButtonBevelAppearance, ListboxAppearance, ListItemAppearance, |
| MediaFullscreenButtonAppearance, MediaMuteButtonAppearance, MediaPlayButtonAppearance, |
| MediaSeekBackButtonAppearance, MediaSeekForwardButtonAppearance, MediaSliderAppearance, MediaSliderThumbAppearance, |
| MenulistAppearance, MenulistButtonAppearance, MenulistTextAppearance, MenulistTextFieldAppearance, |
| ScrollbarButtonUpAppearance, ScrollbarButtonDownAppearance, |
| ScrollbarButtonLeftAppearance, ScrollbarButtonRightAppearance, |
| ScrollbarTrackHorizontalAppearance, ScrollbarTrackVerticalAppearance, |
| ScrollbarThumbHorizontalAppearance, ScrollbarThumbVerticalAppearance, |
| ScrollbarGripperHorizontalAppearance, ScrollbarGripperVerticalAppearance, |
| SliderHorizontalAppearance, SliderVerticalAppearance, SliderThumbHorizontalAppearance, |
| SliderThumbVerticalAppearance, CaretAppearance, SearchFieldAppearance, SearchFieldDecorationAppearance, |
| SearchFieldResultsDecorationAppearance, SearchFieldResultsButtonAppearance, |
| SearchFieldCancelButtonAppearance, TextFieldAppearance, TextAreaAppearance |
| }; |
| |
| enum EListStyleType { |
| DISC, CIRCLE, SQUARE, LDECIMAL, DECIMAL_LEADING_ZERO, |
| LOWER_ROMAN, UPPER_ROMAN, LOWER_GREEK, |
| LOWER_ALPHA, LOWER_LATIN, UPPER_ALPHA, UPPER_LATIN, |
| HEBREW, ARMENIAN, GEORGIAN, CJK_IDEOGRAPHIC, |
| HIRAGANA, KATAKANA, HIRAGANA_IROHA, KATAKANA_IROHA, LNONE |
| }; |
| |
| struct CounterDirectives { |
| CounterDirectives() : m_reset(false), m_increment(false) { } |
| |
| bool m_reset; |
| int m_resetValue; |
| bool m_increment; |
| int m_incrementValue; |
| }; |
| |
| bool operator==(const CounterDirectives&, const CounterDirectives&); |
| inline bool operator!=(const CounterDirectives& a, const CounterDirectives& b) { return !(a == b); } |
| |
| typedef HashMap<RefPtr<AtomicStringImpl>, CounterDirectives> CounterDirectiveMap; |
| |
| class CounterContent { |
| public: |
| CounterContent(const AtomicString& identifier, EListStyleType style, const AtomicString& separator) |
| : m_identifier(identifier), m_listStyle(style), m_separator(separator) |
| { |
| } |
| |
| const AtomicString& identifier() const { return m_identifier; } |
| EListStyleType listStyle() const { return m_listStyle; } |
| const AtomicString& separator() const { return m_separator; } |
| |
| private: |
| AtomicString m_identifier; |
| EListStyleType m_listStyle; |
| AtomicString m_separator; |
| }; |
| |
| enum ContentType { |
| CONTENT_NONE, CONTENT_OBJECT, CONTENT_TEXT, CONTENT_COUNTER |
| }; |
| |
| struct ContentData : Noncopyable { |
| ContentData() : m_type(CONTENT_NONE), m_next(0) { } |
| ~ContentData() { clear(); } |
| |
| void clear(); |
| |
| ContentType m_type; |
| union { |
| CachedResource* m_object; |
| StringImpl* m_text; |
| CounterContent* m_counter; |
| } m_content; |
| ContentData* m_next; |
| }; |
| |
| enum EBorderFit { BorderFitBorder, BorderFitLines }; |
| |
| enum ETimingFunctionType { LinearTimingFunction, CubicBezierTimingFunction }; |
| |
| struct TimingFunction |
| { |
| TimingFunction() |
| : m_type(CubicBezierTimingFunction) |
| , m_x1(.25) |
| , m_y1(.1) |
| , m_x2(.25) |
| , m_y2(1.0) |
| {} |
| |
| TimingFunction(ETimingFunctionType timingFunction, double x1 = .0, double y1 = .0, double x2 = .0, double y2 = .0) |
| : m_type(timingFunction) |
| , m_x1(x1) |
| , m_y1(y1) |
| , m_x2(x2) |
| , m_y2(y2) |
| { |
| } |
| |
| bool operator==(const TimingFunction& o) const { return m_type == o.m_type && m_x1 == o.m_x1 && m_y1 == o.m_y1 && m_x2 == o.m_x2 && m_y2 == o.m_y2; } |
| |
| double x1() const { return m_x1; } |
| double y1() const { return m_y1; } |
| double x2() const { return m_x2; } |
| double y2() const { return m_y2; } |
| |
| ETimingFunctionType type() const { return m_type; } |
| |
| private: |
| ETimingFunctionType m_type; |
| |
| double m_x1; |
| double m_y1; |
| double m_x2; |
| double m_y2; |
| }; |
| |
| struct Transition { |
| public: |
| Transition(); |
| ~Transition(); |
| |
| Transition* next() const { return m_next; } |
| Transition* next() { return m_next; } |
| |
| bool isTransitionDurationSet() const { return m_durationSet; } |
| bool isTransitionRepeatCountSet() const { return m_repeatCountSet; } |
| bool isTransitionTimingFunctionSet() const { return m_timingFunctionSet; } |
| bool isTransitionPropertySet() const { return m_propertySet; } |
| |
| bool isEmpty() const { return !m_durationSet && !m_repeatCountSet && !m_timingFunctionSet && !m_propertySet; } |
| void clearTransitionDuration() { m_durationSet = false; } |
| void clearTransitionRepeatCount() { m_repeatCountSet = false; } |
| void clearTransitionTimingFunction() { m_timingFunctionSet = false; } |
| void clearTransitionProperty() { m_propertySet = false; } |
| |
| int transitionDuration() const { return m_duration; } |
| int transitionRepeatCount() const { return m_repeatCount; } |
| const TimingFunction& transitionTimingFunction() const { return m_timingFunction; } |
| int transitionProperty() const { return m_property; } |
| |
| void setTransitionDuration(int d) { m_duration = d; m_durationSet = true; } |
| void setTransitionRepeatCount(int c) { m_repeatCount = c; m_repeatCountSet = true; } |
| void setTransitionTimingFunction(const TimingFunction& f) { m_timingFunction = f; m_timingFunctionSet = true; } |
| void setTransitionProperty(int t) { m_property = t; m_propertySet = true; } |
| |
| void setNext(Transition* n) { if (m_next != n) { delete m_next; m_next = n; } } |
| |
| Transition& operator=(const Transition& o); |
| Transition(const Transition& o); |
| |
| bool operator==(const Transition& o) const; |
| bool operator!=(const Transition& o) const { |
| return !(*this == o); |
| } |
| |
| void fillUnsetProperties(); |
| |
| int m_duration; |
| int m_repeatCount; |
| TimingFunction m_timingFunction; |
| int m_property; |
| |
| bool m_durationSet; |
| bool m_repeatCountSet; |
| bool m_timingFunctionSet; |
| bool m_propertySet; |
| |
| Transition* m_next; |
| }; |
| |
| // This struct is for rarely used non-inherited CSS3, CSS2, and WebKit-specific properties. |
| // By grouping them together, we save space, and only allocate this object when someone |
| // actually uses one of these properties. |
| class StyleRareNonInheritedData : public RefCounted<StyleRareNonInheritedData> { |
| public: |
| StyleRareNonInheritedData(); |
| ~StyleRareNonInheritedData(); |
| StyleRareNonInheritedData(const StyleRareNonInheritedData&); |
| |
| #if ENABLE(XBL) |
| bool bindingsEquivalent(const StyleRareNonInheritedData&) const; |
| #endif |
| |
| bool operator==(const StyleRareNonInheritedData&) const; |
| bool operator!=(const StyleRareNonInheritedData& o) const { return !(*this == o); } |
| |
| bool shadowDataEquivalent(const StyleRareNonInheritedData& o) const; |
| bool transitionDataEquivalent(const StyleRareNonInheritedData&) const; |
| |
| int lineClamp; // An Apple extension. |
| Vector<StyleDashboardRegion> m_dashboardRegions; |
| float opacity; // Whether or not we're transparent. |
| |
| DataRef<StyleFlexibleBoxData> flexibleBox; // Flexible box properties |
| DataRef<StyleMarqueeData> marquee; // Marquee properties |
| DataRef<StyleMultiColData> m_multiCol; // CSS3 multicol properties |
| DataRef<StyleTransformData> m_transform; // Transform properties (rotate, scale, skew, etc.) |
| |
| ContentData* m_content; |
| CounterDirectiveMap* m_counterDirectives; |
| |
| unsigned userDrag : 2; // EUserDrag |
| bool textOverflow : 1; // Whether or not lines that spill out should be truncated with "..." |
| unsigned marginTopCollapse : 2; // EMarginCollapse |
| unsigned marginBottomCollapse : 2; // EMarginCollapse |
| unsigned matchNearestMailBlockquoteColor : 1; // EMatchNearestMailBlockquoteColor, FIXME: This property needs to be eliminated. It should never have been added. |
| unsigned m_appearance : 6; // EAppearance |
| unsigned m_borderFit : 1; // EBorderFit |
| ShadowData* m_boxShadow; // For box-shadow decorations. |
| |
| Transition* m_transition; |
| |
| #if ENABLE(XBL) |
| BindingURI* bindingURI; // The XBL binding URI list. |
| #endif |
| }; |
| |
| // This struct is for rarely used inherited CSS3, CSS2, and WebKit-specific properties. |
| // By grouping them together, we save space, and only allocate this object when someone |
| // actually uses one of these properties. |
| class StyleRareInheritedData : public RefCounted<StyleRareInheritedData> { |
| public: |
| StyleRareInheritedData(); |
| ~StyleRareInheritedData(); |
| StyleRareInheritedData(const StyleRareInheritedData& o); |
| |
| bool operator==(const StyleRareInheritedData& o) const; |
| bool operator!=(const StyleRareInheritedData &o) const { |
| return !(*this == o); |
| } |
| bool shadowDataEquivalent(const StyleRareInheritedData&) const; |
| |
| Color textStrokeColor; |
| float textStrokeWidth; |
| Color textFillColor; |
| |
| ShadowData* textShadow; // Our text shadow information for shadowed text drawing. |
| AtomicString highlight; // Apple-specific extension for custom highlight rendering. |
| unsigned textSecurity : 2; // ETextSecurity |
| unsigned userModify : 2; // EUserModify (editing) |
| unsigned wordBreak : 2; // EWordBreak |
| unsigned wordWrap : 1; // EWordWrap |
| unsigned nbspMode : 1; // ENBSPMode |
| unsigned khtmlLineBreak : 1; // EKHTMLLineBreak |
| bool textSizeAdjust : 1; // An Apple extension. |
| unsigned resize : 2; // EResize |
| unsigned userSelect : 1; // EUserSelect |
| }; |
| |
| //------------------------------------------------ |
| // Inherited attributes. |
| // |
| |
| enum EWhiteSpace { |
| NORMAL, PRE, PRE_WRAP, PRE_LINE, NOWRAP, KHTML_NOWRAP |
| }; |
| |
| enum ETextAlign { |
| TAAUTO, LEFT, RIGHT, CENTER, JUSTIFY, WEBKIT_LEFT, WEBKIT_RIGHT, WEBKIT_CENTER |
| }; |
| |
| enum ETextTransform { |
| CAPITALIZE, UPPERCASE, LOWERCASE, TTNONE |
| }; |
| |
| enum ETextDecoration { |
| TDNONE = 0x0 , UNDERLINE = 0x1, OVERLINE = 0x2, LINE_THROUGH= 0x4, BLINK = 0x8 |
| }; |
| |
| enum EPageBreak { |
| PBAUTO, PBALWAYS, PBAVOID |
| }; |
| |
| class StyleInheritedData : public RefCounted<StyleInheritedData> { |
| public: |
| StyleInheritedData(); |
| ~StyleInheritedData(); |
| StyleInheritedData(const StyleInheritedData& o ); |
| |
| bool operator==(const StyleInheritedData& o) const; |
| bool operator != ( const StyleInheritedData &o ) const { |
| return !(*this == o); |
| } |
| |
| Length indent; |
| // could be packed in a short but doesn't |
| // make a difference currently because of padding |
| Length line_height; |
| |
| CachedImage *style_image; |
| RefPtr<CursorList> cursorData; |
| |
| Font font; |
| Color color; |
| |
| short horizontal_border_spacing; |
| short vertical_border_spacing; |
| |
| // Paged media properties. |
| short widows; |
| short orphans; |
| unsigned page_break_inside : 2; // EPageBreak |
| }; |
| |
| |
| enum EEmptyCell { |
| SHOW, HIDE |
| }; |
| |
| enum ECaptionSide { |
| CAPTOP, CAPBOTTOM, CAPLEFT, CAPRIGHT |
| }; |
| |
| enum EListStylePosition { OUTSIDE, INSIDE }; |
| |
| enum EVisibility { VISIBLE, HIDDEN, COLLAPSE }; |
| |
| enum ECursor { |
| CURSOR_AUTO, CURSOR_CROSS, CURSOR_DEFAULT, CURSOR_POINTER, CURSOR_MOVE, CURSOR_VERTICAL_TEXT, CURSOR_CELL, CURSOR_CONTEXT_MENU, |
| CURSOR_ALIAS, CURSOR_PROGRESS, CURSOR_NO_DROP, CURSOR_NOT_ALLOWED, CURSOR_WEBKIT_ZOOM_IN, CURSOR_WEBKIT_ZOOM_OUT, |
| CURSOR_E_RESIZE, CURSOR_NE_RESIZE, CURSOR_NW_RESIZE, CURSOR_N_RESIZE, CURSOR_SE_RESIZE, CURSOR_SW_RESIZE, |
| CURSOR_S_RESIZE, CURSOR_W_RESIZE, CURSOR_EW_RESIZE, CURSOR_NS_RESIZE, CURSOR_NESW_RESIZE, CURSOR_NWSE_RESIZE, |
| CURSOR_COL_RESIZE, CURSOR_ROW_RESIZE, CURSOR_TEXT, CURSOR_WAIT, CURSOR_HELP, CURSOR_ALL_SCROLL, |
| CURSOR_COPY, CURSOR_NONE |
| }; |
| |
| struct CursorData { |
| CursorData() |
| : cursorImage(0) |
| {} |
| |
| bool operator==(const CursorData& o) const { |
| return hotSpot == o.hotSpot && cursorImage == o.cursorImage && cursorFragmentId == o.cursorFragmentId; |
| } |
| bool operator!=(const CursorData& o) const { return !(*this == o); } |
| |
| IntPoint hotSpot; // for CSS3 support |
| CachedImage* cursorImage; // weak pointer, the CSSValueImage takes care of deleting cursorImage |
| String cursorFragmentId; // only used for SVGCursorElement, a direct pointer would get stale |
| }; |
| |
| class CursorList : public RefCounted<CursorList> { |
| public: |
| const CursorData& operator[](int i) const { |
| return m_vector[i]; |
| } |
| |
| bool operator==(const CursorList& o) const { return m_vector == o.m_vector; } |
| bool operator!=(const CursorList& o) const { return m_vector != o.m_vector; } |
| |
| size_t size() const { return m_vector.size(); } |
| void append(const CursorData& cursorData) { m_vector.append(cursorData); } |
| |
| private: |
| Vector<CursorData> m_vector; |
| }; |
| |
| //------------------------------------------------ |
| |
| enum EDisplay { |
| INLINE, BLOCK, LIST_ITEM, RUN_IN, COMPACT, INLINE_BLOCK, |
| TABLE, INLINE_TABLE, TABLE_ROW_GROUP, |
| TABLE_HEADER_GROUP, TABLE_FOOTER_GROUP, TABLE_ROW, |
| TABLE_COLUMN_GROUP, TABLE_COLUMN, TABLE_CELL, |
| TABLE_CAPTION, BOX, INLINE_BOX, NONE |
| }; |
| |
| class RenderStyle { |
| friend class CSSStyleSelector; |
| |
| public: |
| // static pseudo styles. Dynamic ones are produced on the fly. |
| enum PseudoId { NOPSEUDO, FIRST_LINE, FIRST_LETTER, BEFORE, AFTER, SELECTION, FIRST_LINE_INHERITED, FILE_UPLOAD_BUTTON, SLIDER_THUMB, |
| SEARCH_CANCEL_BUTTON, SEARCH_DECORATION, SEARCH_RESULTS_DECORATION, SEARCH_RESULTS_BUTTON, MEDIA_CONTROLS_PANEL, |
| MEDIA_CONTROLS_PLAY_BUTTON, MEDIA_CONTROLS_MUTE_BUTTON, MEDIA_CONTROLS_TIMELINE, MEDIA_CONTROLS_TIME_DISPLAY, |
| MEDIA_CONTROLS_SEEK_BACK_BUTTON, MEDIA_CONTROLS_SEEK_FORWARD_BUTTON , MEDIA_CONTROLS_FULLSCREEN_BUTTON }; |
| static const int FIRST_INTERNAL_PSEUDOID = FILE_UPLOAD_BUTTON; |
| |
| void ref() { m_ref++; } |
| void deref(RenderArena* arena) { |
| if (m_ref) m_ref--; |
| if (!m_ref) |
| arenaDelete(arena); |
| } |
| bool hasOneRef() { return m_ref==1; } |
| int refCount() const { return m_ref; } |
| |
| // Overloaded new operator. Derived classes must override operator new |
| // in order to allocate out of the RenderArena. |
| void* operator new(size_t sz, RenderArena* renderArena) throw(); |
| |
| // Overridden to prevent the normal delete from being called. |
| void operator delete(void* ptr, size_t sz); |
| |
| private: |
| void arenaDelete(RenderArena *arena); |
| |
| protected: |
| |
| // !START SYNC!: Keep this in sync with the copy constructor in RenderStyle.cpp |
| |
| // inherit |
| struct InheritedFlags { |
| bool operator==( const InheritedFlags &other ) const { |
| return (_empty_cells == other._empty_cells) && |
| (_caption_side == other._caption_side) && |
| (_list_style_type == other._list_style_type) && |
| (_list_style_position == other._list_style_position) && |
| (_visibility == other._visibility) && |
| (_text_align == other._text_align) && |
| (_text_transform == other._text_transform) && |
| (_text_decorations == other._text_decorations) && |
| (_text_transform == other._text_transform) && |
| (_cursor_style == other._cursor_style) && |
| (_direction == other._direction) && |
| (_border_collapse == other._border_collapse) && |
| (_white_space == other._white_space) && |
| (_box_direction == other._box_direction) && |
| (_visuallyOrdered == other._visuallyOrdered) && |
| (_htmlHacks == other._htmlHacks) && |
| (_force_backgrounds_to_white == other._force_backgrounds_to_white); |
| } |
| |
| bool operator!=( const InheritedFlags &other ) const { |
| return !(*this == other); |
| } |
| |
| unsigned _empty_cells : 1; // EEmptyCell |
| unsigned _caption_side : 2; // ECaptionSide |
| unsigned _list_style_type : 5 ; // EListStyleType |
| unsigned _list_style_position : 1; // EListStylePosition |
| unsigned _visibility : 2; // EVisibility |
| unsigned _text_align : 4; // ETextAlign |
| unsigned _text_transform : 2; // ETextTransform |
| unsigned _text_decorations : 4; |
| unsigned _cursor_style : 6; // ECursor |
| unsigned _direction : 1; // TextDirection |
| bool _border_collapse : 1 ; |
| unsigned _white_space : 3; // EWhiteSpace |
| unsigned _box_direction : 1; // EBoxDirection (CSS3 box_direction property, flexible box layout module) |
| |
| // non CSS2 inherited |
| bool _visuallyOrdered : 1; |
| bool _htmlHacks :1; |
| bool _force_backgrounds_to_white : 1; |
| } inherited_flags; |
| |
| // don't inherit |
| struct NonInheritedFlags { |
| bool operator==( const NonInheritedFlags &other ) const { |
| return (_effectiveDisplay == other._effectiveDisplay) && |
| (_originalDisplay == other._originalDisplay) && |
| (_bg_repeat == other._bg_repeat) && |
| (_overflowX == other._overflowX) && |
| (_overflowY == other._overflowY) && |
| (_vertical_align == other._vertical_align) && |
| (_clear == other._clear) && |
| (_position == other._position) && |
| (_floating == other._floating) && |
| (_table_layout == other._table_layout) && |
| (_page_break_before == other._page_break_before) && |
| (_page_break_after == other._page_break_after) && |
| (_styleType == other._styleType) && |
| (_affectedByHover == other._affectedByHover) && |
| (_affectedByActive == other._affectedByActive) && |
| (_affectedByDrag == other._affectedByDrag) && |
| (_pseudoBits == other._pseudoBits) && |
| (_unicodeBidi == other._unicodeBidi); |
| } |
| |
| bool operator!=( const NonInheritedFlags &other ) const { |
| return !(*this == other); |
| } |
| |
| unsigned _effectiveDisplay : 5; // EDisplay |
| unsigned _originalDisplay : 5; // EDisplay |
| unsigned _bg_repeat : 2; // EBackgroundRepeat |
| unsigned _overflowX : 4; // EOverflow |
| unsigned _overflowY : 4; // EOverflow |
| unsigned _vertical_align : 4; // EVerticalAlign |
| unsigned _clear : 2; // EClear |
| unsigned _position : 2; // EPosition |
| unsigned _floating : 2; // EFloat |
| unsigned _table_layout : 1; // ETableLayout |
| |
| unsigned _page_break_before : 2; // EPageBreak |
| unsigned _page_break_after : 2; // EPageBreak |
| |
| unsigned _styleType : 5; // PseudoId |
| bool _affectedByHover : 1; |
| bool _affectedByActive : 1; |
| bool _affectedByDrag : 1; |
| unsigned _pseudoBits : 6; |
| unsigned _unicodeBidi : 2; // EUnicodeBidi |
| } noninherited_flags; |
| |
| // non-inherited attributes |
| DataRef<StyleBoxData> box; |
| DataRef<StyleVisualData> visual; |
| DataRef<StyleBackgroundData> background; |
| DataRef<StyleSurroundData> surround; |
| DataRef<StyleRareNonInheritedData> rareNonInheritedData; |
| |
| // inherited attributes |
| DataRef<StyleRareInheritedData> rareInheritedData; |
| DataRef<StyleInheritedData> inherited; |
| |
| // list of associated pseudo styles |
| RenderStyle* pseudoStyle; |
| |
| unsigned m_pseudoState : 3; // PseudoState |
| bool m_affectedByAttributeSelectors : 1; |
| bool m_unique : 1; |
| |
| // Bits for dynamic child matching. |
| bool m_affectedByEmpty : 1; |
| bool m_emptyState : 1; |
| |
| // We optimize for :first-child and :last-child. The other positional child selectors like nth-child or |
| // *-child-of-type, we will just give up and re-evaluate whenever children change at all. |
| bool m_childrenAffectedByFirstChildRules : 1; |
| bool m_childrenAffectedByLastChildRules : 1; |
| bool m_childrenAffectedByForwardPositionalRules : 1; |
| bool m_childrenAffectedByBackwardPositionalRules : 1; |
| bool m_firstChildState : 1; |
| bool m_lastChildState : 1; |
| unsigned m_childIndex : 19; // Plenty of bits to cache an index. |
| |
| int m_ref; |
| |
| #if ENABLE(SVG) |
| DataRef<SVGRenderStyle> m_svgStyle; |
| #endif |
| |
| // !END SYNC! |
| |
| protected: |
| void setBitDefaults() |
| { |
| inherited_flags._empty_cells = initialEmptyCells(); |
| inherited_flags._caption_side = initialCaptionSide(); |
| inherited_flags._list_style_type = initialListStyleType(); |
| inherited_flags._list_style_position = initialListStylePosition(); |
| inherited_flags._visibility = initialVisibility(); |
| inherited_flags._text_align = initialTextAlign(); |
| inherited_flags._text_transform = initialTextTransform(); |
| inherited_flags._text_decorations = initialTextDecoration(); |
| inherited_flags._cursor_style = initialCursor(); |
| inherited_flags._direction = initialDirection(); |
| inherited_flags._border_collapse = initialBorderCollapse(); |
| inherited_flags._white_space = initialWhiteSpace(); |
| inherited_flags._visuallyOrdered = initialVisuallyOrdered(); |
| inherited_flags._htmlHacks=false; |
| inherited_flags._box_direction = initialBoxDirection(); |
| inherited_flags._force_backgrounds_to_white = false; |
| |
| noninherited_flags._effectiveDisplay = noninherited_flags._originalDisplay = initialDisplay(); |
| noninherited_flags._bg_repeat = initialBackgroundRepeat(); |
| noninherited_flags._overflowX = initialOverflowX(); |
| noninherited_flags._overflowY = initialOverflowY(); |
| noninherited_flags._vertical_align = initialVerticalAlign(); |
| noninherited_flags._clear = initialClear(); |
| noninherited_flags._position = initialPosition(); |
| noninherited_flags._floating = initialFloating(); |
| noninherited_flags._table_layout = initialTableLayout(); |
| noninherited_flags._page_break_before = initialPageBreak(); |
| noninherited_flags._page_break_after = initialPageBreak(); |
| noninherited_flags._styleType = NOPSEUDO; |
| noninherited_flags._affectedByHover = false; |
| noninherited_flags._affectedByActive = false; |
| noninherited_flags._affectedByDrag = false; |
| noninherited_flags._pseudoBits = 0; |
| noninherited_flags._unicodeBidi = initialUnicodeBidi(); |
| } |
| |
| public: |
| |
| RenderStyle(); |
| // used to create the default style. |
| RenderStyle(bool); |
| RenderStyle(const RenderStyle&); |
| |
| ~RenderStyle(); |
| |
| void inheritFrom(const RenderStyle* inheritParent); |
| |
| PseudoId styleType() { return static_cast<PseudoId>(noninherited_flags._styleType); } |
| void setStyleType(PseudoId styleType) { noninherited_flags._styleType = styleType; } |
| |
| RenderStyle* getPseudoStyle(PseudoId pi); |
| void addPseudoStyle(RenderStyle* pseudo); |
| |
| bool affectedByHoverRules() const { return noninherited_flags._affectedByHover; } |
| bool affectedByActiveRules() const { return noninherited_flags._affectedByActive; } |
| bool affectedByDragRules() const { return noninherited_flags._affectedByDrag; } |
| |
| void setAffectedByHoverRules(bool b) { noninherited_flags._affectedByHover = b; } |
| void setAffectedByActiveRules(bool b) { noninherited_flags._affectedByActive = b; } |
| void setAffectedByDragRules(bool b) { noninherited_flags._affectedByDrag = b; } |
| |
| bool operator==(const RenderStyle& other) const; |
| bool isFloating() const { return !(noninherited_flags._floating == FNONE); } |
| bool hasMargin() const { return surround->margin.nonZero(); } |
| bool hasBorder() const { return surround->border.hasBorder(); } |
| bool hasPadding() const { return surround->padding.nonZero(); } |
| bool hasOffset() const { return surround->offset.nonZero(); } |
| |
| bool hasBackground() const { if (backgroundColor().isValid() && backgroundColor().alpha() > 0) |
| return true; |
| return background->m_background.hasImage(); } |
| bool hasFixedBackgroundImage() const { return background->m_background.hasFixedImage(); } |
| bool hasAppearance() const { return appearance() != NoAppearance; } |
| |
| bool visuallyOrdered() const { return inherited_flags._visuallyOrdered; } |
| void setVisuallyOrdered(bool b) { inherited_flags._visuallyOrdered = b; } |
| |
| bool isStyleAvailable() const; |
| |
| bool hasPseudoStyle(PseudoId pseudo) const; |
| void setHasPseudoStyle(PseudoId pseudo); |
| |
| // attribute getter methods |
| |
| EDisplay display() const { return static_cast<EDisplay>(noninherited_flags._effectiveDisplay); } |
| EDisplay originalDisplay() const { return static_cast<EDisplay>(noninherited_flags._originalDisplay); } |
| |
| Length left() const { return surround->offset.left; } |
| Length right() const { return surround->offset.right; } |
| Length top() const { return surround->offset.top; } |
| Length bottom() const { return surround->offset.bottom; } |
| |
| EPosition position() const { return static_cast<EPosition>(noninherited_flags._position); } |
| EFloat floating() const { return static_cast<EFloat>(noninherited_flags._floating); } |
| |
| Length width() const { return box->width; } |
| Length height() const { return box->height; } |
| Length minWidth() const { return box->min_width; } |
| Length maxWidth() const { return box->max_width; } |
| Length minHeight() const { return box->min_height; } |
| Length maxHeight() const { return box->max_height; } |
| |
| const BorderData& border() const { return surround->border; } |
| const BorderValue& borderLeft() const { return surround->border.left; } |
| const BorderValue& borderRight() const { return surround->border.right; } |
| const BorderValue& borderTop() const { return surround->border.top; } |
| const BorderValue& borderBottom() const { return surround->border.bottom; } |
| |
| const BorderImage& borderImage() const { return surround->border.image; } |
| |
| IntSize borderTopLeftRadius() const { return surround->border.topLeft; } |
| IntSize borderTopRightRadius() const { return surround->border.topRight; } |
| IntSize borderBottomLeftRadius() const { return surround->border.bottomLeft; } |
| IntSize borderBottomRightRadius() const { return surround->border.bottomRight; } |
| bool hasBorderRadius() const { return surround->border.hasBorderRadius(); } |
| |
| unsigned short borderLeftWidth() const { return surround->border.borderLeftWidth(); } |
| EBorderStyle borderLeftStyle() const { return surround->border.left.style(); } |
| const Color& borderLeftColor() const { return surround->border.left.color; } |
| bool borderLeftIsTransparent() const { return surround->border.left.isTransparent(); } |
| unsigned short borderRightWidth() const { return surround->border.borderRightWidth(); } |
| EBorderStyle borderRightStyle() const { return surround->border.right.style(); } |
| const Color& borderRightColor() const { return surround->border.right.color; } |
| bool borderRightIsTransparent() const { return surround->border.right.isTransparent(); } |
| unsigned short borderTopWidth() const { return surround->border.borderTopWidth(); } |
| EBorderStyle borderTopStyle() const { return surround->border.top.style(); } |
| const Color& borderTopColor() const { return surround->border.top.color; } |
| bool borderTopIsTransparent() const { return surround->border.top.isTransparent(); } |
| unsigned short borderBottomWidth() const { return surround->border.borderBottomWidth(); } |
| EBorderStyle borderBottomStyle() const { return surround->border.bottom.style(); } |
| const Color& borderBottomColor() const { return surround->border.bottom.color; } |
| bool borderBottomIsTransparent() const { return surround->border.bottom.isTransparent(); } |
| |
| unsigned short outlineSize() const { return max(0, outlineWidth() + outlineOffset()); } |
| unsigned short outlineWidth() const { |
| if (background->m_outline.style() == BNONE || background->m_outline.style() == BHIDDEN) |
| return 0; |
| return background->m_outline.width; |
| } |
| bool hasOutline() const { return outlineWidth() > 0 && outlineStyle() > BHIDDEN; } |
| EBorderStyle outlineStyle() const { return background->m_outline.style(); } |
| bool outlineStyleIsAuto() const { return background->m_outline._auto; } |
| const Color & outlineColor() const { return background->m_outline.color; } |
| |
| EOverflow overflowX() const { return static_cast<EOverflow>(noninherited_flags._overflowX); } |
| EOverflow overflowY() const { return static_cast<EOverflow>(noninherited_flags._overflowY); } |
| |
| EVisibility visibility() const { return static_cast<EVisibility>(inherited_flags._visibility); } |
| EVerticalAlign verticalAlign() const { return static_cast<EVerticalAlign>(noninherited_flags._vertical_align); } |
| Length verticalAlignLength() const { return box->vertical_align; } |
| |
| Length clipLeft() const { return visual->clip.left; } |
| Length clipRight() const { return visual->clip.right; } |
| Length clipTop() const { return visual->clip.top; } |
| Length clipBottom() const { return visual->clip.bottom; } |
| LengthBox clip() const { return visual->clip; } |
| bool hasClip() const { return visual->hasClip; } |
| |
| EUnicodeBidi unicodeBidi() const { return static_cast<EUnicodeBidi>(noninherited_flags._unicodeBidi); } |
| |
| EClear clear() const { return static_cast<EClear>(noninherited_flags._clear); } |
| ETableLayout tableLayout() const { return static_cast<ETableLayout>(noninherited_flags._table_layout); } |
| |
| const Font& font() { return inherited->font; } |
| const FontDescription& fontDescription() { return inherited->font.fontDescription(); } |
| int fontSize() const { return inherited->font.pixelSize(); } |
| |
| const Color & color() const { return inherited->color; } |
| Length textIndent() const { return inherited->indent; } |
| ETextAlign textAlign() const { return static_cast<ETextAlign>(inherited_flags._text_align); } |
| ETextTransform textTransform() const { return static_cast<ETextTransform>(inherited_flags._text_transform); } |
| int textDecorationsInEffect() const { return inherited_flags._text_decorations; } |
| int textDecoration() const { return visual->textDecoration; } |
| int wordSpacing() const { return inherited->font.wordSpacing(); } |
| int letterSpacing() const { return inherited->font.letterSpacing(); } |
| |
| TextDirection direction() const { return static_cast<TextDirection>(inherited_flags._direction); } |
| Length lineHeight() const { return inherited->line_height; } |
| |
| EWhiteSpace whiteSpace() const { return static_cast<EWhiteSpace>(inherited_flags._white_space); } |
| static bool autoWrap(EWhiteSpace ws) { |
| // Nowrap and pre don't automatically wrap. |
| return ws != NOWRAP && ws != PRE; |
| } |
| bool autoWrap() const { |
| return autoWrap(whiteSpace()); |
| } |
| static bool preserveNewline(EWhiteSpace ws) { |
| // Normal and nowrap do not preserve newlines. |
| return ws != NORMAL && ws != NOWRAP; |
| } |
| bool preserveNewline() const { |
| return preserveNewline(whiteSpace()); |
| } |
| static bool collapseWhiteSpace(EWhiteSpace ws) { |
| // Pre and prewrap do not collapse whitespace. |
| return ws != PRE && ws != PRE_WRAP; |
| } |
| bool collapseWhiteSpace() const { |
| return collapseWhiteSpace(whiteSpace()); |
| } |
| bool isCollapsibleWhiteSpace(UChar c) const { |
| switch (c) { |
| case ' ': |
| case '\t': |
| return collapseWhiteSpace(); |
| case '\n': |
| return !preserveNewline(); |
| } |
| return false; |
| } |
| bool breakOnlyAfterWhiteSpace() const { |
| return whiteSpace() == PRE_WRAP || khtmlLineBreak() == AFTER_WHITE_SPACE; |
| } |
| bool breakWords() const { |
| return wordBreak() == BreakWordBreak || wordWrap() == BreakWordWrap; |
| } |
| |
| const Color & backgroundColor() const { return background->m_color; } |
| CachedImage *backgroundImage() const { return background->m_background.m_image; } |
| EBackgroundRepeat backgroundRepeat() const { return static_cast<EBackgroundRepeat>(background->m_background.m_bgRepeat); } |
| CompositeOperator backgroundComposite() const { return static_cast<CompositeOperator>(background->m_background.m_bgComposite); } |
| bool backgroundAttachment() const { return background->m_background.m_bgAttachment; } |
| EBackgroundBox backgroundClip() const { return static_cast<EBackgroundBox>(background->m_background.m_bgClip); } |
| EBackgroundBox backgroundOrigin() const { return static_cast<EBackgroundBox>(background->m_background.m_bgOrigin); } |
| Length backgroundXPosition() const { return background->m_background.m_xPosition; } |
| Length backgroundYPosition() const { return background->m_background.m_yPosition; } |
| LengthSize backgroundSize() const { return background->m_background.m_backgroundSize; } |
| BackgroundLayer* accessBackgroundLayers() { return &(background.access()->m_background); } |
| const BackgroundLayer* backgroundLayers() const { return &(background->m_background); } |
| |
| // returns true for collapsing borders, false for separate borders |
| bool borderCollapse() const { return inherited_flags._border_collapse; } |
| short horizontalBorderSpacing() const { return inherited->horizontal_border_spacing; } |
| short verticalBorderSpacing() const { return inherited->vertical_border_spacing; } |
| EEmptyCell emptyCells() const { return static_cast<EEmptyCell>(inherited_flags._empty_cells); } |
| ECaptionSide captionSide() const { return static_cast<ECaptionSide>(inherited_flags._caption_side); } |
| |
| short counterIncrement() const { return visual->counterIncrement; } |
| short counterReset() const { return visual->counterReset; } |
| |
| EListStyleType listStyleType() const { return static_cast<EListStyleType>(inherited_flags._list_style_type); } |
| CachedImage *listStyleImage() const { return inherited->style_image; } |
| EListStylePosition listStylePosition() const { return static_cast<EListStylePosition>(inherited_flags._list_style_position); } |
| |
| Length marginTop() const { return surround->margin.top; } |
| Length marginBottom() const { return surround->margin.bottom; } |
| Length marginLeft() const { return surround->margin.left; } |
| Length marginRight() const { return surround->margin.right; } |
| |
| Length paddingTop() const { return surround->padding.top; } |
| Length paddingBottom() const { return surround->padding.bottom; } |
| Length paddingLeft() const { return surround->padding.left; } |
| Length paddingRight() const { return surround->padding.right; } |
| |
| ECursor cursor() const { return static_cast<ECursor>(inherited_flags._cursor_style); } |
| |
| CursorList* cursors() const { return inherited->cursorData.get(); } |
| |
| short widows() const { return inherited->widows; } |
| short orphans() const { return inherited->orphans; } |
| EPageBreak pageBreakInside() const { return static_cast<EPageBreak>(inherited->page_break_inside); } |
| EPageBreak pageBreakBefore() const { return static_cast<EPageBreak>(noninherited_flags._page_break_before); } |
| EPageBreak pageBreakAfter() const { return static_cast<EPageBreak>(noninherited_flags._page_break_after); } |
| |
| // CSS3 Getter Methods |
| #if ENABLE(XBL) |
| BindingURI* bindingURIs() const { return rareNonInheritedData->bindingURI; } |
| #endif |
| int outlineOffset() const { |
| if (background->m_outline.style() == BNONE || background->m_outline.style() == BHIDDEN) |
| return 0; |
| return background->m_outline._offset; |
| } |
| ShadowData* textShadow() const { return rareInheritedData->textShadow; } |
| Color textStrokeColor() const { return rareInheritedData->textStrokeColor; } |
| float textStrokeWidth() const { return rareInheritedData->textStrokeWidth; } |
| Color textFillColor() const { return rareInheritedData->textFillColor; } |
| float opacity() const { return rareNonInheritedData->opacity; } |
| EAppearance appearance() const { return static_cast<EAppearance>(rareNonInheritedData->m_appearance); } |
| EBoxAlignment boxAlign() const { return static_cast<EBoxAlignment>(rareNonInheritedData->flexibleBox->align); } |
| EBoxDirection boxDirection() const { return static_cast<EBoxDirection>(inherited_flags._box_direction); } |
| float boxFlex() { return rareNonInheritedData->flexibleBox->flex; } |
| unsigned int boxFlexGroup() const { return rareNonInheritedData->flexibleBox->flex_group; } |
| EBoxLines boxLines() { return static_cast<EBoxLines>(rareNonInheritedData->flexibleBox->lines); } |
| unsigned int boxOrdinalGroup() const { return rareNonInheritedData->flexibleBox->ordinal_group; } |
| EBoxOrient boxOrient() const { return static_cast<EBoxOrient>(rareNonInheritedData->flexibleBox->orient); } |
| EBoxAlignment boxPack() const { return static_cast<EBoxAlignment>(rareNonInheritedData->flexibleBox->pack); } |
| ShadowData* boxShadow() const { return rareNonInheritedData->m_boxShadow; } |
| EBoxSizing boxSizing() const { return static_cast<EBoxSizing>(box->boxSizing); } |
| Length marqueeIncrement() const { return rareNonInheritedData->marquee->increment; } |
| int marqueeSpeed() const { return rareNonInheritedData->marquee->speed; } |
| int marqueeLoopCount() const { return rareNonInheritedData->marquee->loops; } |
| EMarqueeBehavior marqueeBehavior() const { return static_cast<EMarqueeBehavior>(rareNonInheritedData->marquee->behavior); } |
| EMarqueeDirection marqueeDirection() const { return static_cast<EMarqueeDirection>(rareNonInheritedData->marquee->direction); } |
| EUserModify userModify() const { return static_cast<EUserModify>(rareInheritedData->userModify); } |
| EUserDrag userDrag() const { return static_cast<EUserDrag>(rareNonInheritedData->userDrag); } |
| EUserSelect userSelect() const { return static_cast<EUserSelect>(rareInheritedData->userSelect); } |
| bool textOverflow() const { return rareNonInheritedData->textOverflow; } |
| EMarginCollapse marginTopCollapse() const { return static_cast<EMarginCollapse>(rareNonInheritedData->marginTopCollapse); } |
| EMarginCollapse marginBottomCollapse() const { return static_cast<EMarginCollapse>(rareNonInheritedData->marginBottomCollapse); } |
| EWordBreak wordBreak() const { return static_cast<EWordBreak>(rareInheritedData->wordBreak); } |
| EWordWrap wordWrap() const { return static_cast<EWordWrap>(rareInheritedData->wordWrap); } |
| ENBSPMode nbspMode() const { return static_cast<ENBSPMode>(rareInheritedData->nbspMode); } |
| EKHTMLLineBreak khtmlLineBreak() const { return static_cast<EKHTMLLineBreak>(rareInheritedData->khtmlLineBreak); } |
| EMatchNearestMailBlockquoteColor matchNearestMailBlockquoteColor() const { return static_cast<EMatchNearestMailBlockquoteColor>(rareNonInheritedData->matchNearestMailBlockquoteColor); } |
| const AtomicString& highlight() const { return rareInheritedData->highlight; } |
| EBorderFit borderFit() const { return static_cast<EBorderFit>(rareNonInheritedData->m_borderFit); } |
| EResize resize() const { return static_cast<EResize>(rareInheritedData->resize); } |
| float columnWidth() const { return rareNonInheritedData->m_multiCol->m_width; } |
| bool hasAutoColumnWidth() const { return rareNonInheritedData->m_multiCol->m_autoWidth; } |
| unsigned short columnCount() const { return rareNonInheritedData->m_multiCol->m_count; } |
| bool hasAutoColumnCount() const { return rareNonInheritedData->m_multiCol->m_autoCount; } |
| float columnGap() const { return rareNonInheritedData->m_multiCol->m_gap; } |
| bool hasNormalColumnGap() const { return rareNonInheritedData->m_multiCol->m_normalGap; } |
| const Color& columnRuleColor() const { return rareNonInheritedData->m_multiCol->m_rule.color; } |
| EBorderStyle columnRuleStyle() const { return rareNonInheritedData->m_multiCol->m_rule.style(); } |
| unsigned short columnRuleWidth() const { return rareNonInheritedData->m_multiCol->ruleWidth(); } |
| bool columnRuleIsTransparent() const { return rareNonInheritedData->m_multiCol->m_rule.isTransparent(); } |
| EPageBreak columnBreakBefore() const { return static_cast<EPageBreak>(rareNonInheritedData->m_multiCol->m_breakBefore); } |
| EPageBreak columnBreakInside() const { return static_cast<EPageBreak>(rareNonInheritedData->m_multiCol->m_breakInside); } |
| EPageBreak columnBreakAfter() const { return static_cast<EPageBreak>(rareNonInheritedData->m_multiCol->m_breakAfter); } |
| const TransformOperations& transform() const { return rareNonInheritedData->m_transform->m_operations; } |
| Length transformOriginX() const { return rareNonInheritedData->m_transform->m_x; } |
| Length transformOriginY() const { return rareNonInheritedData->m_transform->m_y; } |
| bool hasTransform() const { return !rareNonInheritedData->m_transform->m_operations.isEmpty(); } |
| void applyTransform(AffineTransform&, const IntSize& borderBoxSize) const; |
| // End CSS3 Getters |
| |
| // Apple-specific property getter methods |
| Transition* accessTransitions(); |
| const Transition* transitions() const { return rareNonInheritedData->m_transition; } |
| int lineClamp() const { return rareNonInheritedData->lineClamp; } |
| bool textSizeAdjust() const { return rareInheritedData->textSizeAdjust; } |
| ETextSecurity textSecurity() const { return static_cast<ETextSecurity>(rareInheritedData->textSecurity); } |
| |
| // attribute setter methods |
| |
| void setDisplay(EDisplay v) { noninherited_flags._effectiveDisplay = v; } |
| void setOriginalDisplay(EDisplay v) { noninherited_flags._originalDisplay = v; } |
| void setPosition(EPosition v) { noninherited_flags._position = v; } |
| void setFloating(EFloat v) { noninherited_flags._floating = v; } |
| |
| void setLeft(Length v) { SET_VAR(surround,offset.left,v) } |
| void setRight(Length v) { SET_VAR(surround,offset.right,v) } |
| void setTop(Length v) { SET_VAR(surround,offset.top,v) } |
| void setBottom(Length v){ SET_VAR(surround,offset.bottom,v) } |
| |
| void setWidth(Length v) { SET_VAR(box,width,v) } |
| void setHeight(Length v) { SET_VAR(box,height,v) } |
| |
| void setMinWidth(Length v) { SET_VAR(box,min_width,v) } |
| void setMaxWidth(Length v) { SET_VAR(box,max_width,v) } |
| void setMinHeight(Length v) { SET_VAR(box,min_height,v) } |
| void setMaxHeight(Length v) { SET_VAR(box,max_height,v) } |
| |
| Vector<StyleDashboardRegion> dashboardRegions() const { return rareNonInheritedData->m_dashboardRegions; } |
| void setDashboardRegions(Vector<StyleDashboardRegion> regions) { SET_VAR(rareNonInheritedData,m_dashboardRegions,regions); } |
| void setDashboardRegion(int type, const String& label, Length t, Length r, Length b, Length l, bool append) { |
| StyleDashboardRegion region; |
| region.label = label; |
| region.offset.top = t; |
| region.offset.right = r; |
| region.offset.bottom = b; |
| region.offset.left = l; |
| region.type = type; |
| if (!append) |
| rareNonInheritedData.access()->m_dashboardRegions.clear(); |
| rareNonInheritedData.access()->m_dashboardRegions.append(region); |
| } |
| |
| void resetBorder() { resetBorderImage(); resetBorderTop(); resetBorderRight(); resetBorderBottom(); resetBorderLeft(); resetBorderRadius(); } |
| void resetBorderTop() { SET_VAR(surround, border.top, BorderValue()) } |
| void resetBorderRight() { SET_VAR(surround, border.right, BorderValue()) } |
| void resetBorderBottom() { SET_VAR(surround, border.bottom, BorderValue()) } |
| void resetBorderLeft() { SET_VAR(surround, border.left, BorderValue()) } |
| void resetBorderImage() { SET_VAR(surround, border.image, BorderImage()) } |
| void resetBorderRadius() { resetBorderTopLeftRadius(); resetBorderTopRightRadius(); resetBorderBottomLeftRadius(); resetBorderBottomRightRadius(); } |
| void resetBorderTopLeftRadius() { SET_VAR(surround, border.topLeft, initialBorderRadius()) } |
| void resetBorderTopRightRadius() { SET_VAR(surround, border.topRight, initialBorderRadius()) } |
| void resetBorderBottomLeftRadius() { SET_VAR(surround, border.bottomLeft, initialBorderRadius()) } |
| void resetBorderBottomRightRadius() { SET_VAR(surround, border.bottomRight, initialBorderRadius()) } |
| |
| void resetOutline() { SET_VAR(background, m_outline, OutlineValue()) } |
| |
| void setBackgroundColor(const Color& v) { SET_VAR(background, m_color, v) } |
| |
| void setBorderImage(const BorderImage& b) { SET_VAR(surround, border.image, b) } |
| |
| void setBorderTopLeftRadius(const IntSize& s) { SET_VAR(surround, border.topLeft, s) } |
| void setBorderTopRightRadius(const IntSize& s) { SET_VAR(surround, border.topRight, s) } |
| void setBorderBottomLeftRadius(const IntSize& s) { SET_VAR(surround, border.bottomLeft, s) } |
| void setBorderBottomRightRadius(const IntSize& s) { SET_VAR(surround, border.bottomRight, s) } |
| void setBorderRadius(const IntSize& s) { |
| setBorderTopLeftRadius(s); setBorderTopRightRadius(s); setBorderBottomLeftRadius(s); setBorderBottomRightRadius(s); |
| } |
| |
| void setBorderLeftWidth(unsigned short v) { SET_VAR(surround, border.left.width, v) } |
| void setBorderLeftStyle(EBorderStyle v) { SET_VAR(surround, border.left.m_style, v) } |
| void setBorderLeftColor(const Color & v) { SET_VAR(surround, border.left.color, v) } |
| void setBorderRightWidth(unsigned short v) { SET_VAR(surround, border.right.width, v) } |
| void setBorderRightStyle(EBorderStyle v) { SET_VAR(surround, border.right.m_style, v) } |
| void setBorderRightColor(const Color & v) { SET_VAR(surround, border.right.color, v) } |
| void setBorderTopWidth(unsigned short v) { SET_VAR(surround, border.top.width, v) } |
| void setBorderTopStyle(EBorderStyle v) { SET_VAR(surround, border.top.m_style, v) } |
| void setBorderTopColor(const Color & v) { SET_VAR(surround, border.top.color, v) } |
| void setBorderBottomWidth(unsigned short v) { SET_VAR(surround, border.bottom.width, v) } |
| void setBorderBottomStyle(EBorderStyle v) { SET_VAR(surround, border.bottom.m_style, v) } |
| void setBorderBottomColor(const Color & v) { SET_VAR(surround, border.bottom.color, v) } |
| void setOutlineWidth(unsigned short v) { SET_VAR(background, m_outline.width, v) } |
| void setOutlineStyle(EBorderStyle v, bool isAuto = false) |
| { |
| SET_VAR(background, m_outline.m_style, v) |
| SET_VAR(background, m_outline._auto, isAuto) |
| } |
| void setOutlineColor(const Color & v) { SET_VAR(background,m_outline.color,v) } |
| |
| void setOverflowX(EOverflow v) { noninherited_flags._overflowX = v; } |
| void setOverflowY(EOverflow v) { noninherited_flags._overflowY = v; } |
| void setVisibility(EVisibility v) { inherited_flags._visibility = v; } |
| void setVerticalAlign(EVerticalAlign v) { noninherited_flags._vertical_align = v; } |
| void setVerticalAlignLength(Length l) { SET_VAR(box, vertical_align, l ) } |
| |
| void setHasClip(bool b = true) { SET_VAR(visual,hasClip,b) } |
| void setClipLeft(Length v) { SET_VAR(visual,clip.left,v) } |
| void setClipRight(Length v) { SET_VAR(visual,clip.right,v) } |
| void setClipTop(Length v) { SET_VAR(visual,clip.top,v) } |
| void setClipBottom(Length v) { SET_VAR(visual,clip.bottom,v) } |
| void setClip( Length top, Length right, Length bottom, Length left ); |
| |
| void setUnicodeBidi( EUnicodeBidi b ) { noninherited_flags._unicodeBidi = b; } |
| |
| void setClear(EClear v) { noninherited_flags._clear = v; } |
| void setTableLayout(ETableLayout v) { noninherited_flags._table_layout = v; } |
| |
| bool setFontDescription(const FontDescription& v) { |
| if (inherited->font.fontDescription() != v) { |
| inherited.access()->font = Font(v, inherited->font.letterSpacing(), inherited->font.wordSpacing()); |
| return true; |
| } |
| return false; |
| } |
| |
| void setColor(const Color & v) { SET_VAR(inherited,color,v) } |
| void setTextIndent(Length v) { SET_VAR(inherited,indent,v) } |
| void setTextAlign(ETextAlign v) { inherited_flags._text_align = v; } |
| void setTextTransform(ETextTransform v) { inherited_flags._text_transform = v; } |
| void addToTextDecorationsInEffect(int v) { inherited_flags._text_decorations |= v; } |
| void setTextDecorationsInEffect(int v) { inherited_flags._text_decorations = v; } |
| void setTextDecoration(int v) { SET_VAR(visual, textDecoration, v); } |
| void setDirection(TextDirection v) { inherited_flags._direction = v; } |
| void setLineHeight(Length v) { SET_VAR(inherited,line_height,v) } |
| |
| void setWhiteSpace(EWhiteSpace v) { inherited_flags._white_space = v; } |
| |
| void setWordSpacing(int v) { inherited.access()->font.setWordSpacing(v); } |
| void setLetterSpacing(int v) { inherited.access()->font.setLetterSpacing(v); } |
| |
| void clearBackgroundLayers() { background.access()->m_background = BackgroundLayer(); } |
| void inheritBackgroundLayers(const BackgroundLayer& parent) { background.access()->m_background = parent; } |
| void adjustBackgroundLayers(); |
| |
| void setBorderCollapse(bool collapse) { inherited_flags._border_collapse = collapse; } |
| void setHorizontalBorderSpacing(short v) { SET_VAR(inherited,horizontal_border_spacing,v) } |
| void setVerticalBorderSpacing(short v) { SET_VAR(inherited,vertical_border_spacing,v) } |
| void setEmptyCells(EEmptyCell v) { inherited_flags._empty_cells = v; } |
| void setCaptionSide(ECaptionSide v) { inherited_flags._caption_side = v; } |
| |
| |
| void setCounterIncrement(short v) { SET_VAR(visual,counterIncrement,v) } |
| void setCounterReset(short v) { SET_VAR(visual,counterReset,v) } |
| |
| void setListStyleType(EListStyleType v) { inherited_flags._list_style_type = v; } |
| void setListStyleImage(CachedImage *v) { SET_VAR(inherited,style_image,v)} |
| void setListStylePosition(EListStylePosition v) { inherited_flags._list_style_position = v; } |
| |
| void resetMargin() { SET_VAR(surround, margin, LengthBox(Fixed)) } |
| void setMarginTop(Length v) { SET_VAR(surround,margin.top,v) } |
| void setMarginBottom(Length v) { SET_VAR(surround,margin.bottom,v) } |
| void setMarginLeft(Length v) { SET_VAR(surround,margin.left,v) } |
| void setMarginRight(Length v) { SET_VAR(surround,margin.right,v) } |
| |
| void resetPadding() { SET_VAR(surround, padding, LengthBox(Auto)) } |
| void setPaddingTop(Length v) { SET_VAR(surround,padding.top,v) } |
| void setPaddingBottom(Length v) { SET_VAR(surround,padding.bottom,v) } |
| void setPaddingLeft(Length v) { SET_VAR(surround,padding.left,v) } |
| void setPaddingRight(Length v) { SET_VAR(surround,padding.right,v) } |
| |
| void setCursor( ECursor c ) { inherited_flags._cursor_style = c; } |
| void addCursor(CachedImage*, const IntPoint& = IntPoint()); |
| void addSVGCursor(const String&); |
| void setCursorList(PassRefPtr<CursorList>); |
| void clearCursorList(); |
| |
| bool forceBackgroundsToWhite() const { return inherited_flags._force_backgrounds_to_white; } |
| void setForceBackgroundsToWhite(bool b=true) { inherited_flags._force_backgrounds_to_white = b; } |
| |
| bool htmlHacks() const { return inherited_flags._htmlHacks; } |
| void setHtmlHacks(bool b=true) { inherited_flags._htmlHacks = b; } |
| |
| bool hasAutoZIndex() { return box->z_auto; } |
| void setHasAutoZIndex() { SET_VAR(box, z_auto, true); SET_VAR(box, z_index, 0) } |
| int zIndex() const { return box->z_index; } |
| void setZIndex(int v) { SET_VAR(box, z_auto, false); SET_VAR(box, z_index, v) } |
| |
| void setWidows(short w) { SET_VAR(inherited, widows, w); } |
| void setOrphans(short o) { SET_VAR(inherited, orphans, o); } |
| void setPageBreakInside(EPageBreak b) { SET_VAR(inherited, page_break_inside, b); } |
| void setPageBreakBefore(EPageBreak b) { noninherited_flags._page_break_before = b; } |
| void setPageBreakAfter(EPageBreak b) { noninherited_flags._page_break_after = b; } |
| |
| // CSS3 Setters |
| #if ENABLE(XBL) |
| void deleteBindingURIs() { |
| delete rareNonInheritedData->bindingURI; |
| SET_VAR(rareNonInheritedData, bindingURI, (BindingURI*) 0); |
| } |
| void inheritBindingURIs(BindingURI* other) { |
| SET_VAR(rareNonInheritedData, bindingURI, other->copy()); |
| } |
| void addBindingURI(StringImpl* uri); |
| #endif |
| void setOutlineOffset(int v) { SET_VAR(background, m_outline._offset, v) } |
| void setTextShadow(ShadowData* val, bool add=false); |
| void setTextStrokeColor(const Color& c) { SET_VAR(rareInheritedData, textStrokeColor, c) } |
| void setTextStrokeWidth(float w) { SET_VAR(rareInheritedData, textStrokeWidth, w) } |
| void setTextFillColor(const Color& c) { SET_VAR(rareInheritedData, textFillColor, c) } |
| void setOpacity(float f) { SET_VAR(rareNonInheritedData, opacity, f); } |
| void setAppearance(EAppearance a) { SET_VAR(rareNonInheritedData, m_appearance, a); } |
| void setBoxAlign(EBoxAlignment a) { SET_VAR(rareNonInheritedData.access()->flexibleBox, align, a); } |
| void setBoxDirection(EBoxDirection d) { inherited_flags._box_direction = d; } |
| void setBoxFlex(float f) { SET_VAR(rareNonInheritedData.access()->flexibleBox, flex, f); } |
| void setBoxFlexGroup(unsigned int fg) { SET_VAR(rareNonInheritedData.access()->flexibleBox, flex_group, fg); } |
| void setBoxLines(EBoxLines l) { SET_VAR(rareNonInheritedData.access()->flexibleBox, lines, l); } |
| void setBoxOrdinalGroup(unsigned int og) { SET_VAR(rareNonInheritedData.access()->flexibleBox, ordinal_group, og); } |
| void setBoxOrient(EBoxOrient o) { SET_VAR(rareNonInheritedData.access()->flexibleBox, orient, o); } |
| void setBoxPack(EBoxAlignment p) { SET_VAR(rareNonInheritedData.access()->flexibleBox, pack, p); } |
| void setBoxShadow(ShadowData* val, bool add=false); |
| void setBoxSizing(EBoxSizing s) { SET_VAR(box, boxSizing, s); } |
| void setMarqueeIncrement(const Length& f) { SET_VAR(rareNonInheritedData.access()->marquee, increment, f); } |
| void setMarqueeSpeed(int f) { SET_VAR(rareNonInheritedData.access()->marquee, speed, f); } |
| void setMarqueeDirection(EMarqueeDirection d) { SET_VAR(rareNonInheritedData.access()->marquee, direction, d); } |
| void setMarqueeBehavior(EMarqueeBehavior b) { SET_VAR(rareNonInheritedData.access()->marquee, behavior, b); } |
| void setMarqueeLoopCount(int i) { SET_VAR(rareNonInheritedData.access()->marquee, loops, i); } |
| void setUserModify(EUserModify u) { SET_VAR(rareInheritedData, userModify, u); } |
| void setUserDrag(EUserDrag d) { SET_VAR(rareNonInheritedData, userDrag, d); } |
| void setUserSelect(EUserSelect s) { SET_VAR(rareInheritedData, userSelect, s); } |
| void setTextOverflow(bool b) { SET_VAR(rareNonInheritedData, textOverflow, b); } |
| void setMarginTopCollapse(EMarginCollapse c) { SET_VAR(rareNonInheritedData, marginTopCollapse, c); } |
| void setMarginBottomCollapse(EMarginCollapse c) { SET_VAR(rareNonInheritedData, marginBottomCollapse, c); } |
| void setWordBreak(EWordBreak b) { SET_VAR(rareInheritedData, wordBreak, b); } |
| void setWordWrap(EWordWrap b) { SET_VAR(rareInheritedData, wordWrap, b); } |
| void setNBSPMode(ENBSPMode b) { SET_VAR(rareInheritedData, nbspMode, b); } |
| void setKHTMLLineBreak(EKHTMLLineBreak b) { SET_VAR(rareInheritedData, khtmlLineBreak, b); } |
| void setMatchNearestMailBlockquoteColor(EMatchNearestMailBlockquoteColor c) { SET_VAR(rareNonInheritedData, matchNearestMailBlockquoteColor, c); } |
| void setHighlight(const AtomicString& h) { SET_VAR(rareInheritedData, highlight, h); } |
| void setBorderFit(EBorderFit b) { SET_VAR(rareNonInheritedData, m_borderFit, b); } |
| void setResize(EResize r) { SET_VAR(rareInheritedData, resize, r); } |
| void setColumnWidth(float f) { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_autoWidth, false); SET_VAR(rareNonInheritedData.access()->m_multiCol, m_width, f); } |
| void setHasAutoColumnWidth() { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_autoWidth, true); SET_VAR(rareNonInheritedData.access()->m_multiCol, m_width, 0); } |
| void setColumnCount(unsigned short c) { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_autoCount, false); SET_VAR(rareNonInheritedData.access()->m_multiCol, m_count, c); } |
| void setHasAutoColumnCount() { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_autoCount, true); SET_VAR(rareNonInheritedData.access()->m_multiCol, m_count, 0); } |
| void setColumnGap(float f) { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_normalGap, false); SET_VAR(rareNonInheritedData.access()->m_multiCol, m_gap, f); } |
| void setHasNormalColumnGap() { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_normalGap, true); SET_VAR(rareNonInheritedData.access()->m_multiCol, m_gap, 0); } |
| void setColumnRuleColor(const Color& c) { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_rule.color, c); } |
| void setColumnRuleStyle(EBorderStyle b) { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_rule.m_style, b); } |
| void setColumnRuleWidth(unsigned short w) { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_rule.width, w); } |
| void resetColumnRule() { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_rule, BorderValue()) } |
| void setColumnBreakBefore(EPageBreak p) { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_breakBefore, p); } |
| void setColumnBreakInside(EPageBreak p) { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_breakInside, p); } |
| void setColumnBreakAfter(EPageBreak p) { SET_VAR(rareNonInheritedData.access()->m_multiCol, m_breakAfter, p); } |
| void setTransform(const TransformOperations& ops) { SET_VAR(rareNonInheritedData.access()->m_transform, m_operations, ops); } |
| void setTransformOriginX(Length l) { SET_VAR(rareNonInheritedData.access()->m_transform, m_x, l); } |
| void setTransformOriginY(Length l) { SET_VAR(rareNonInheritedData.access()->m_transform, m_y, l); } |
| // End CSS3 Setters |
| |
| // Apple-specific property setters |
| void clearTransitions() { delete rareNonInheritedData.access()->m_transition; rareNonInheritedData.access()->m_transition = 0; } |
| void inheritTransitions(const Transition* parent) { clearTransitions(); if (parent) rareNonInheritedData.access()->m_transition = new Transition(*parent); } |
| void adjustTransitions(); |
| void setLineClamp(int c) { SET_VAR(rareNonInheritedData, lineClamp, c); } |
| void setTextSizeAdjust(bool b) { SET_VAR(rareInheritedData, textSizeAdjust, b); } |
| void setTextSecurity(ETextSecurity aTextSecurity) { SET_VAR(rareInheritedData, textSecurity, aTextSecurity); } |
| |
| #if ENABLE(SVG) |
| const SVGRenderStyle* svgStyle() const { return m_svgStyle.get(); } |
| SVGRenderStyle* accessSVGStyle() { return m_svgStyle.access(); } |
| #endif |
| |
| const ContentData* contentData() const { return rareNonInheritedData->m_content; } |
| bool contentDataEquivalent(const RenderStyle* otherStyle) const; |
| void clearContent(); |
| void setContent(StringImpl*, bool add = false); |
| void setContent(CachedResource*, bool add = false); |
| void setContent(CounterContent*, bool add = false); |
| |
| const CounterDirectiveMap* counterDirectives() const; |
| CounterDirectiveMap& accessCounterDirectives(); |
| |
| bool inheritedNotEqual(RenderStyle* other) const; |
| |
| // The difference between two styles. The following values are used: |
| // (1) Equal - The two styles are identical |
| // (2) Repaint - The object just needs to be repainted. |
| // (3) RepaintLayer - The layer and its descendant layers needs to be repainted. |
| // (4) Layout - A layout is required. |
| enum Diff { Equal, Repaint, RepaintLayer, Layout }; |
| Diff diff( const RenderStyle *other ) const; |
| |
| bool isDisplayReplacedType() { |
| return display() == INLINE_BLOCK || display() == INLINE_BOX || display() == INLINE_TABLE; |
| } |
| bool isDisplayInlineType() { |
| return display() == INLINE || isDisplayReplacedType(); |
| } |
| bool isOriginalDisplayInlineType() { |
| return originalDisplay() == INLINE || originalDisplay() == INLINE_BLOCK || |
| originalDisplay() == INLINE_BOX || originalDisplay() == INLINE_TABLE; |
| } |
| |
| // To obtain at any time the pseudo state for a given link. |
| PseudoState pseudoState() const { return static_cast<PseudoState>(m_pseudoState); } |
| void setPseudoState(PseudoState s) { m_pseudoState = s; } |
| |
| // To tell if this style matched attribute selectors. This makes it impossible to share. |
| bool affectedByAttributeSelectors() const { return m_affectedByAttributeSelectors; } |
| void setAffectedByAttributeSelectors() { m_affectedByAttributeSelectors = true; } |
| |
| bool unique() const { return m_unique; } |
| void setUnique() { m_unique = true; } |
| |
| // Methods for indicating the style is affected by dynamic updates (e.g., children changing, our position changing in our sibling list, etc.) |
| bool affectedByEmpty() const { return m_affectedByEmpty; } |
| bool emptyState() const { return m_emptyState; } |
| void setEmptyState(bool b) { m_affectedByEmpty = true; m_unique = true; m_emptyState = b; } |
| bool childrenAffectedByFirstChildRules() const { return m_childrenAffectedByFirstChildRules; } |
| void setChildrenAffectedByFirstChildRules() { m_childrenAffectedByFirstChildRules = true; } |
| bool childrenAffectedByLastChildRules() const { return m_childrenAffectedByLastChildRules; } |
| void setChildrenAffectedByLastChildRules() { m_childrenAffectedByLastChildRules = true; } |
| bool childrenAffectedByForwardPositionalRules() const { return m_childrenAffectedByForwardPositionalRules; } |
| void setChildrenAffectedByForwardPositionalRules() { m_childrenAffectedByForwardPositionalRules = true; } |
| bool childrenAffectedByBackwardPositionalRules() const { return m_childrenAffectedByBackwardPositionalRules; } |
| void setChildrenAffectedByBackwardPositionalRules() { m_childrenAffectedByBackwardPositionalRules = true; } |
| bool firstChildState() const { return m_firstChildState; } |
| void setFirstChildState() { m_firstChildState = true; } |
| bool lastChildState() const { return m_lastChildState; } |
| void setLastChildState() { m_lastChildState = true; } |
| unsigned childIndex() const { return m_childIndex; } |
| void setChildIndex(unsigned index) { m_childIndex = index; } |
| |
| // Initial values for all the properties |
| static bool initialBackgroundAttachment() { return true; } |
| static EBackgroundBox initialBackgroundClip() { return BGBORDER; } |
| static EBackgroundBox initialBackgroundOrigin() { return BGPADDING; } |
| static EBackgroundRepeat initialBackgroundRepeat() { return REPEAT; } |
| static CompositeOperator initialBackgroundComposite() { return CompositeSourceOver; } |
| static LengthSize initialBackgroundSize() { return LengthSize(); } |
| static bool initialBorderCollapse() { return false; } |
| static EBorderStyle initialBorderStyle() { return BNONE; } |
| static BorderImage initialBorderImage() { return BorderImage(); } |
| static IntSize initialBorderRadius() { return IntSize(0,0); } |
| static ECaptionSide initialCaptionSide() { return CAPTOP; } |
| static EClear initialClear() { return CNONE; } |
| static TextDirection initialDirection() { return LTR; } |
| static EDisplay initialDisplay() { return INLINE; } |
| static EEmptyCell initialEmptyCells() { return SHOW; } |
| static EFloat initialFloating() { return FNONE; } |
| static EListStylePosition initialListStylePosition() { return OUTSIDE; } |
| static EListStyleType initialListStyleType() { return DISC; } |
| static EOverflow initialOverflowX() { return OVISIBLE; } |
| static EOverflow initialOverflowY() { return OVISIBLE; } |
| static EPageBreak initialPageBreak() { return PBAUTO; } |
| static EPosition initialPosition() { return StaticPosition; } |
| static ETableLayout initialTableLayout() { return TAUTO; } |
| static EUnicodeBidi initialUnicodeBidi() { return UBNormal; } |
| static ETextTransform initialTextTransform() { return TTNONE; } |
| static EVisibility initialVisibility() { return VISIBLE; } |
| static EWhiteSpace initialWhiteSpace() { return NORMAL; } |
| static Length initialBackgroundXPosition() { return Length(0.0, Percent); } |
| static Length initialBackgroundYPosition() { return Length(0.0, Percent); } |
| static short initialHorizontalBorderSpacing() { return 0; } |
| static short initialVerticalBorderSpacing() { return 0; } |
| static ECursor initialCursor() { return CURSOR_AUTO; } |
| static Color initialColor() { return Color::black; } |
| static CachedImage* initialBackgroundImage() { return 0; } |
| static CachedImage* initialListStyleImage() { return 0; } |
| static unsigned short initialBorderWidth() { return 3; } |
| static int initialLetterWordSpacing() { return 0; } |
| static Length initialSize() { return Length(); } |
| static Length initialMinSize() { return Length(0, Fixed); } |
| static Length initialMaxSize() { return Length(undefinedLength, Fixed); } |
| static Length initialOffset() { return Length(); } |
| static Length initialMargin() { return Length(Fixed); } |
| static Length initialPadding() { return Length(Fixed); } |
| static Length initialTextIndent() { return Length(Fixed); } |
| static EVerticalAlign initialVerticalAlign() { return BASELINE; } |
| static int initialWidows() { return 2; } |
| static int initialOrphans() { return 2; } |
| static Length initialLineHeight() { return Length(-100.0, Percent); } |
| static ETextAlign initialTextAlign() { return TAAUTO; } |
| static ETextDecoration initialTextDecoration() { return TDNONE; } |
| static int initialOutlineOffset() { return 0; } |
| static float initialOpacity() { return 1.0f; } |
| static EBoxAlignment initialBoxAlign() { return BSTRETCH; } |
| static EBoxDirection initialBoxDirection() { return BNORMAL; } |
| static EBoxLines initialBoxLines() { return SINGLE; } |
| static EBoxOrient initialBoxOrient() { return HORIZONTAL; } |
| static EBoxAlignment initialBoxPack() { return BSTART; } |
| static float initialBoxFlex() { return 0.0f; } |
| static int initialBoxFlexGroup() { return 1; } |
| static int initialBoxOrdinalGroup() { return 1; } |
| static EBoxSizing initialBoxSizing() { return CONTENT_BOX; } |
| static int initialMarqueeLoopCount() { return -1; } |
| static int initialMarqueeSpeed() { return 85; } |
| static Length initialMarqueeIncrement() { return Length(6, Fixed); } |
| static EMarqueeBehavior initialMarqueeBehavior() { return MSCROLL; } |
| static EMarqueeDirection initialMarqueeDirection() { return MAUTO; } |
| static EUserModify initialUserModify() { return READ_ONLY; } |
| static EUserDrag initialUserDrag() { return DRAG_AUTO; } |
| static EUserSelect initialUserSelect() { return SELECT_TEXT; } |
| static bool initialTextOverflow() { return false; } |
| static EMarginCollapse initialMarginTopCollapse() { return MCOLLAPSE; } |
| static EMarginCollapse initialMarginBottomCollapse() { return MCOLLAPSE; } |
| static EWordBreak initialWordBreak() { return NormalWordBreak; } |
| static EWordWrap initialWordWrap() { return NormalWordWrap; } |
| static ENBSPMode initialNBSPMode() { return NBNORMAL; } |
| static EKHTMLLineBreak initialKHTMLLineBreak() { return LBNORMAL; } |
| static EMatchNearestMailBlockquoteColor initialMatchNearestMailBlockquoteColor() { return BCNORMAL; } |
| static const AtomicString& initialHighlight() { return nullAtom; } |
| static EBorderFit initialBorderFit() { return BorderFitBorder; } |
| static EResize initialResize() { return RESIZE_NONE; } |
| static EAppearance initialAppearance() { return NoAppearance; } |
| static bool initialVisuallyOrdered() { return false; } |
| static float initialTextStrokeWidth() { return 0; } |
| static unsigned short initialColumnCount() { return 1; } |
| static const TransformOperations& initialTransform() { static TransformOperations ops; return ops; } |
| static Length initialTransformOriginX() { return Length(50.0, Percent); } |
| static Length initialTransformOriginY() { return Length(50.0, Percent); } |
| |
| // Keep these at the end. |
| static int initialTransitionDuration() { return 0; } |
| static int initialTransitionRepeatCount() { return 1; } |
| static TimingFunction initialTransitionTimingFunction() { return TimingFunction(); } |
| static int initialTransitionProperty() { return cAnimateAll; } |
| static int initialLineClamp() { return -1; } |
| static bool initialTextSizeAdjust() { return true; } |
| static ETextSecurity initialTextSecurity() { return TSNONE; } |
| static const Vector<StyleDashboardRegion>& initialDashboardRegions(); |
| static const Vector<StyleDashboardRegion>& noneDashboardRegions(); |
| }; |
| |
| } // namespace WebCore |
| |
| #endif |