RenderFragmentContainer.h [plain text]
#pragma once
#include "LayerFragment.h"
#include "RenderBlockFlow.h"
#include "VisiblePosition.h"
#include <memory>
namespace WebCore {
class Element;
class RenderBox;
class RenderBoxFragmentInfo;
class RenderFragmentedFlow;
class RenderFragmentContainer : public RenderBlockFlow {
WTF_MAKE_ISO_ALLOCATED(RenderFragmentContainer);
public:
void styleDidChange(StyleDifference, const RenderStyle* oldStyle) override;
void setFragmentedFlowPortionRect(const LayoutRect& rect) { m_fragmentedFlowPortionRect = rect; }
LayoutRect fragmentedFlowPortionRect() const { return m_fragmentedFlowPortionRect; }
LayoutRect fragmentedFlowPortionOverflowRect();
LayoutPoint fragmentedFlowPortionLocation() const;
virtual void attachFragment();
virtual void detachFragment();
RenderFragmentedFlow* fragmentedFlow() const { return m_fragmentedFlow; }
bool isValid() const { return m_isValid; }
void setIsValid(bool valid) { m_isValid = valid; }
RenderBoxFragmentInfo* renderBoxFragmentInfo(const RenderBox*) const;
RenderBoxFragmentInfo* setRenderBoxFragmentInfo(const RenderBox*, LayoutUnit logicalLeftInset, LayoutUnit logicalRightInset,
bool containingBlockChainIsInset);
std::unique_ptr<RenderBoxFragmentInfo> takeRenderBoxFragmentInfo(const RenderBox*);
void removeRenderBoxFragmentInfo(const RenderBox&);
void deleteAllRenderBoxFragmentInfo();
bool isFirstFragment() const;
bool isLastFragment() const;
virtual bool shouldClipFragmentedFlowContent() const;
virtual LayoutUnit pageLogicalWidth() const;
virtual LayoutUnit pageLogicalHeight() const;
LayoutUnit logicalTopOfFragmentedFlowContentRect(const LayoutRect&) const;
LayoutUnit logicalBottomOfFragmentedFlowContentRect(const LayoutRect&) const;
LayoutUnit logicalTopForFragmentedFlowContent() const { return logicalTopOfFragmentedFlowContentRect(fragmentedFlowPortionRect()); };
LayoutUnit logicalBottomForFragmentedFlowContent() const { return logicalBottomOfFragmentedFlowContentRect(fragmentedFlowPortionRect()); };
virtual LayoutUnit logicalHeightOfAllFragmentedFlowContent() const;
virtual LayoutUnit pageLogicalTopForOffset(LayoutUnit offset) const;
virtual bool isRenderFragmentContainerSet() const { return false; }
virtual void repaintFragmentedFlowContent(const LayoutRect& repaintRect);
virtual void collectLayerFragments(LayerFragments&, const LayoutRect&, const LayoutRect&) { }
virtual void adjustFragmentBoundsFromFragmentedFlowPortionRect(LayoutRect& fragmentBounds) const;
void addLayoutOverflowForBox(const RenderBox*, const LayoutRect&);
void addVisualOverflowForBox(const RenderBox*, const LayoutRect&);
LayoutRect layoutOverflowRectForBox(const RenderBox*);
LayoutRect visualOverflowRectForBox(const RenderBoxModelObject&);
LayoutRect layoutOverflowRectForBoxForPropagation(const RenderBox*);
LayoutRect visualOverflowRectForBoxForPropagation(const RenderBoxModelObject&);
LayoutRect rectFlowPortionForBox(const RenderBox*, const LayoutRect&) const;
void setFragmentObjectsFragmentStyle();
void restoreFragmentObjectsOriginalStyle();
bool canHaveChildren() const override { return false; }
bool canHaveGeneratedChildren() const override { return true; }
VisiblePosition positionForPoint(const LayoutPoint&, const RenderFragmentContainer*) override;
virtual void absoluteQuadsForBoxInFragment(Vector<FloatQuad>&, bool*, const RenderBox*, float, float) { }
protected:
RenderFragmentContainer(Element&, RenderStyle&&, RenderFragmentedFlow*);
RenderFragmentContainer(Document&, RenderStyle&&, RenderFragmentedFlow*);
void ensureOverflowForBox(const RenderBox*, RefPtr<RenderOverflow>&, bool);
void computePreferredLogicalWidths() override;
void computeIntrinsicLogicalWidths(LayoutUnit& minLogicalWidth, LayoutUnit& maxLogicalWidth) const override;
enum OverflowType {
LayoutOverflow = 0,
VisualOverflow
};
LayoutRect overflowRectForFragmentedFlowPortion(const LayoutRect& fragmentedFlowPortionRect, bool isFirstPortion, bool isLastPortion, OverflowType);
void repaintFragmentedFlowContentRectangle(const LayoutRect& repaintRect, const LayoutRect& fragmentedFlowPortionRect, const LayoutPoint& fragmentLocation, const LayoutRect* fragmentedFlowPortionClipRect = 0);
void computeOverflowFromFragmentedFlow();
private:
bool isRenderFragmentContainer() const final { return true; }
const char* renderName() const override { return "RenderFragmentContainer"; }
void insertedIntoTree() override;
void willBeRemovedFromTree() override;
virtual void installFragmentedFlow();
LayoutPoint mapFragmentPointIntoFragmentedFlowCoordinates(const LayoutPoint&);
protected:
RenderFragmentedFlow* m_fragmentedFlow;
private:
LayoutRect m_fragmentedFlowPortionRect;
typedef HashMap<const RenderBox*, std::unique_ptr<RenderBoxFragmentInfo>> RenderBoxFragmentInfoMap;
RenderBoxFragmentInfoMap m_renderBoxFragmentInfo;
bool m_isValid : 1;
};
class CurrentRenderFragmentContainerMaintainer {
WTF_MAKE_NONCOPYABLE(CurrentRenderFragmentContainerMaintainer);
public:
CurrentRenderFragmentContainerMaintainer(RenderFragmentContainer&);
~CurrentRenderFragmentContainerMaintainer();
RenderFragmentContainer& fragment() const { return m_fragment; }
private:
RenderFragmentContainer& m_fragment;
};
}
SPECIALIZE_TYPE_TRAITS_RENDER_OBJECT(RenderFragmentContainer, isRenderFragmentContainer())