1998-10-01 01:01:11 +04:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Netscape Public License
|
|
|
|
* Version 1.0 (the "NPL"); you may not use this file except in
|
|
|
|
* compliance with the NPL. You may obtain a copy of the NPL at
|
|
|
|
* http://www.mozilla.org/NPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the NPL is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* NPL.
|
|
|
|
*
|
|
|
|
* The Initial Developer of this code under the NPL is Netscape
|
|
|
|
* Communications Corporation. Portions created by Netscape are
|
|
|
|
* Copyright (C) 1998 Netscape Communications Corporation. All Rights
|
|
|
|
* Reserved.
|
|
|
|
*/
|
|
|
|
#ifndef nsContainerFrame_h___
|
|
|
|
#define nsContainerFrame_h___
|
|
|
|
|
|
|
|
#include "nsSplittableFrame.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Implementation of a container frame.
|
|
|
|
*/
|
|
|
|
class nsContainerFrame : public nsSplittableFrame
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
NS_IMETHOD SizeOf(nsISizeOfHandler* aHandler) const;
|
|
|
|
|
|
|
|
NS_IMETHOD Init(nsIPresContext& aPresContext, nsIFrame* aChildList);
|
|
|
|
|
|
|
|
NS_IMETHOD DeleteFrame(nsIPresContext& aPresContext);
|
|
|
|
|
|
|
|
NS_IMETHOD DidReflow(nsIPresContext& aPresContext,
|
|
|
|
nsDidReflowStatus aStatus);
|
|
|
|
|
|
|
|
// Painting
|
|
|
|
NS_IMETHOD Paint(nsIPresContext& aPresContext,
|
|
|
|
nsIRenderingContext& aRenderingContext,
|
|
|
|
const nsRect& aDirtyRect);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Pass through the event to the correct child frame.
|
|
|
|
* Return PR_TRUE if the event is consumed.
|
|
|
|
*/
|
|
|
|
NS_IMETHOD HandleEvent(nsIPresContext& aPresContext,
|
|
|
|
nsGUIEvent* aEvent,
|
|
|
|
nsEventStatus& aEventStatus);
|
|
|
|
|
|
|
|
NS_IMETHOD GetCursorAndContentAt(nsIPresContext& aPresContext,
|
|
|
|
const nsPoint& aPoint,
|
|
|
|
nsIFrame** aFrame,
|
|
|
|
nsIContent** aContent,
|
|
|
|
PRInt32& aCursor);
|
|
|
|
|
|
|
|
// Child frame enumeration.
|
|
|
|
// ChildAt() retruns null if the index is not in the range 0 .. ChildCount() - 1.
|
|
|
|
// IndexOf() returns -1 if the frame is not in the child list.
|
|
|
|
NS_IMETHOD FirstChild(nsIFrame*& aFirstChild) const;
|
|
|
|
|
|
|
|
// Debugging
|
|
|
|
NS_IMETHOD List(FILE* out = stdout, PRInt32 aIndent = 0, nsIListFilter *aFilter = nsnull) const;
|
|
|
|
NS_IMETHOD VerifyTree() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the number of children in the sibling list, starting at aChild.
|
|
|
|
* Returns zero if aChild is nsnull.
|
|
|
|
*/
|
|
|
|
static PRInt32 LengthOf(nsIFrame* aChild);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the last frame in the sibling list.
|
|
|
|
* Returns nsnullif aChild is nsnull.
|
|
|
|
*/
|
|
|
|
static nsIFrame* LastFrame(nsIFrame* aChild);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the frame at the specified index relative to aFrame
|
|
|
|
*/
|
|
|
|
static nsIFrame* FrameAt(nsIFrame* aFrame, PRInt32 aIndex);
|
|
|
|
|
|
|
|
// XXX needs to be virtual so that nsBlockFrame can override it
|
|
|
|
virtual PRBool DeleteChildsNextInFlow(nsIPresContext& aPresContext,
|
|
|
|
nsIFrame* aChild);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
// Constructor. Takes as arguments the content object, the index in parent,
|
|
|
|
// and the Frame for the content parent
|
|
|
|
nsContainerFrame(nsIContent* aContent, nsIFrame* aParent);
|
|
|
|
|
|
|
|
virtual ~nsContainerFrame();
|
|
|
|
|
|
|
|
void SizeOfWithoutThis(nsISizeOfHandler* aHandler) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Prepare a continuation frame of this frame for reflow. Appends
|
|
|
|
* it to the flow, sets its content offsets, mLastContentIsComplete,
|
|
|
|
* and style context. Subclasses should invoke this method after
|
|
|
|
* construction of a continuing frame.
|
|
|
|
*/
|
|
|
|
void PrepareContinuingFrame(nsIPresContext& aPresContext,
|
|
|
|
nsIFrame* aParent,
|
|
|
|
nsIStyleContext* aStyleContext,
|
|
|
|
nsContainerFrame* aContFrame);
|
|
|
|
|
|
|
|
|
|
|
|
virtual void PaintChildren(nsIPresContext& aPresContext,
|
|
|
|
nsIRenderingContext& aRenderingContext,
|
|
|
|
const nsRect& aDirtyRect);
|
|
|
|
|
|
|
|
/**
|
1998-10-06 04:27:22 +04:00
|
|
|
* Queries the child frame for the nsIHTMLReflow interface and if it's
|
|
|
|
* supported invokes the WillReflow() and Reflow() member functions. If
|
|
|
|
* the reflow succeeds and the child frame is complete, deletes any
|
|
|
|
* next-in-flows using DeleteChildsNextInFlow()
|
1998-10-01 01:01:11 +04:00
|
|
|
*/
|
1998-10-06 04:27:22 +04:00
|
|
|
nsresult ReflowChild(nsIFrame* aKidFrame,
|
|
|
|
nsIPresContext& aPresContext,
|
|
|
|
nsHTMLReflowMetrics& aDesiredSize,
|
|
|
|
const nsHTMLReflowState& aReflowState,
|
|
|
|
nsReflowStatus& aStatus);
|
1998-10-01 01:01:11 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Moves any frames on both the prev-in-flow's overflow list and the receiver's
|
|
|
|
* overflow to the receiver's child list.
|
|
|
|
*
|
|
|
|
* Resets the overlist pointers to nsnull, and updates the receiver's child
|
|
|
|
* count and content mapping.
|
|
|
|
*
|
|
|
|
* @return PR_TRUE if any frames were moved and PR_FALSE otherwise
|
|
|
|
*/
|
|
|
|
PRBool MoveOverflowToChildList();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Push aFromChild and its next siblings to the next-in-flow. Change the
|
|
|
|
* geometric parent of each frame that's pushed. If there is no next-in-flow
|
|
|
|
* the frames are placed on the overflow list (and the geometric parent is
|
|
|
|
* left unchanged).
|
|
|
|
*
|
|
|
|
* Updates the next-in-flow's child count. Does <b>not</b> update the
|
|
|
|
* pusher's child count.
|
|
|
|
*
|
|
|
|
* @param aFromChild the first child frame to push. It is disconnected from
|
|
|
|
* aPrevSibling
|
|
|
|
* @param aPrevSibling aFromChild's previous sibling. Must not be null. It's
|
|
|
|
* an error to push a parent's first child frame
|
|
|
|
*/
|
|
|
|
void PushChildren(nsIFrame* aFromChild, nsIFrame* aPrevSibling);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Append child list starting at aChild to this frame's child list. Used for
|
|
|
|
* processing of the overflow list.
|
|
|
|
*
|
|
|
|
* Updates this frame's child count and content mapping.
|
|
|
|
*
|
|
|
|
* @param aChild the beginning of the child list
|
|
|
|
* @param aSetParent if true each child's geometric (and content parent if
|
|
|
|
* they're the same) parent is set to this frame.
|
|
|
|
*/
|
|
|
|
void AppendChildren(nsIFrame* aChild, PRBool aSetParent = PR_TRUE);
|
|
|
|
|
|
|
|
virtual void WillDeleteNextInFlowFrame(nsIFrame* aNextInFlow);
|
|
|
|
|
|
|
|
#ifdef NS_DEBUG
|
|
|
|
/**
|
|
|
|
* Returns PR_TRUE if aChild is a child of this frame.
|
|
|
|
*/
|
|
|
|
PRBool IsChild(const nsIFrame* aChild) const;
|
|
|
|
|
|
|
|
void DumpTree() const;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
nsIFrame* mFirstChild;
|
|
|
|
nsIFrame* mOverflowList;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* nsContainerFrame_h___ */
|