gecko/layout/style/nsStyleStructInlines.h
L. David Baron 5ef4421fa5 Bug 781360 patch 3: Rename {nsIFrame,nsStyleContext,nsComputedDOMStyle}::GetStyle* to Style*, since they can never return null. r=dholbert
Except for the changes in:
  layout/generic/nsIFrame.h (part)
  layout/style/nsComputedDOMStyle.h (all)
  layout/style/nsRuleNode.cpp (part)
  layout/style/nsStyleContext.cpp (part)
  layout/style/nsStyleContext.h (part)
(see patch 3b in the bug), this patch was written with the sed script:
s/\<GetStyle\(Font\|Color\|List\|Text\|Visibility\|Quotes\|UserInterface\|TableBorder\|SVG\|Background\|Position\|TextReset\|Display\|Content\|UIReset\|Table\|Margin\|Padding\|Border\|Outline\|XUL\|SVGReset\|Column\)\>/Style\1/g
2013-02-16 13:51:02 -08:00

171 lines
4.3 KiB
C

/* vim: set shiftwidth=2 tabstop=8 autoindent cindent expandtab: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
/*
* Inline methods that belong in nsStyleStruct.h, except that they
* require more headers.
*/
#ifndef nsStyleStructInlines_h_
#define nsStyleStructInlines_h_
#include "nsIFrame.h"
#include "nsStyleStruct.h"
#include "imgIRequest.h"
#include "imgIContainer.h"
inline void
nsStyleBorder::SetBorderImage(imgRequestProxy* aImage)
{
mBorderImageSource = aImage;
mSubImages.Clear();
}
inline imgRequestProxy*
nsStyleBorder::GetBorderImage() const
{
NS_ABORT_IF_FALSE(!mBorderImageSource || mImageTracked,
"Should be tracking any images we're going to use!");
return mBorderImageSource;
}
inline bool nsStyleBorder::IsBorderImageLoaded() const
{
uint32_t status;
return mBorderImageSource &&
NS_SUCCEEDED(mBorderImageSource->GetImageStatus(&status)) &&
(status & imgIRequest::STATUS_LOAD_COMPLETE) &&
!(status & imgIRequest::STATUS_ERROR);
}
inline void
nsStyleBorder::SetSubImage(uint8_t aIndex, imgIContainer* aSubImage) const
{
const_cast<nsStyleBorder*>(this)->mSubImages.ReplaceObjectAt(aSubImage, aIndex);
}
inline imgIContainer*
nsStyleBorder::GetSubImage(uint8_t aIndex) const
{
imgIContainer* subImage = nullptr;
if (aIndex < mSubImages.Count())
subImage = mSubImages[aIndex];
return subImage;
}
bool
nsStyleText::HasTextShadow(const nsIFrame* aFrame) const
{
return mTextShadow && !aFrame->IsSVGText();
}
nsCSSShadowArray*
nsStyleText::GetTextShadow(const nsIFrame* aFrame) const
{
if (aFrame->IsSVGText()) {
return nullptr;
}
return mTextShadow;
}
bool
nsStyleDisplay::IsBlockInside(const nsIFrame* aFrame) const
{
if (aFrame->GetStateBits() & NS_FRAME_IS_SVG_TEXT) {
return aFrame->GetType() == nsGkAtoms::blockFrame;
}
return IsBlockInsideStyle();
}
bool
nsStyleDisplay::IsBlockOutside(const nsIFrame* aFrame) const
{
if (aFrame->GetStateBits() & NS_FRAME_IS_SVG_TEXT) {
return aFrame->GetType() == nsGkAtoms::blockFrame;
}
return IsBlockOutsideStyle();
}
bool
nsStyleDisplay::IsInlineOutside(const nsIFrame* aFrame) const
{
if (aFrame->GetStateBits() & NS_FRAME_IS_SVG_TEXT) {
return aFrame->GetType() != nsGkAtoms::blockFrame;
}
return IsInlineOutsideStyle();
}
bool
nsStyleDisplay::IsOriginalDisplayInlineOutside(const nsIFrame* aFrame) const
{
if (aFrame->GetStateBits() & NS_FRAME_IS_SVG_TEXT) {
return aFrame->GetType() != nsGkAtoms::blockFrame;
}
return IsOriginalDisplayInlineOutsideStyle();
}
uint8_t
nsStyleDisplay::GetDisplay(const nsIFrame* aFrame) const
{
if ((aFrame->GetStateBits() & NS_FRAME_IS_SVG_TEXT) &&
mDisplay != NS_STYLE_DISPLAY_NONE) {
return aFrame->GetType() == nsGkAtoms::blockFrame ?
NS_STYLE_DISPLAY_BLOCK :
NS_STYLE_DISPLAY_INLINE;
}
return mDisplay;
}
bool
nsStyleDisplay::IsFloating(const nsIFrame* aFrame) const
{
return IsFloatingStyle() && !aFrame->IsSVGText();
}
bool
nsStyleDisplay::HasTransform(const nsIFrame* aFrame) const
{
return HasTransformStyle() && aFrame->IsFrameOfType(nsIFrame::eSupportsCSSTransforms);
}
bool
nsStyleDisplay::IsPositioned(const nsIFrame* aFrame) const
{
return (IsAbsolutelyPositionedStyle() ||
IsRelativelyPositionedStyle() ||
HasTransform(aFrame)) &&
!aFrame->IsSVGText();
}
bool
nsStyleDisplay::IsRelativelyPositioned(const nsIFrame* aFrame) const
{
return IsRelativelyPositionedStyle() && !aFrame->IsSVGText();
}
bool
nsStyleDisplay::IsAbsolutelyPositioned(const nsIFrame* aFrame) const
{
return IsAbsolutelyPositionedStyle() && !aFrame->IsSVGText();
}
uint8_t
nsStyleVisibility::GetEffectivePointerEvents(nsIFrame* aFrame) const
{
if (aFrame->GetContent() && !aFrame->GetContent()->GetParent()) {
// The root element has a cluster of frames associated with it
// (root scroll frame, canvas frame, the actual primary frame). Make
// those take their pointer-events value from the root element's primary
// frame.
nsIFrame* f = aFrame->GetContent()->GetPrimaryFrame();
if (f) {
return f->StyleVisibility()->mPointerEvents;
}
}
return mPointerEvents;
}
#endif /* !defined(nsStyleStructInlines_h_) */