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"
|
1999-01-16 01:53:39 +03:00
|
|
|
#include "nsFrameList.h"
|
1998-10-01 01:01:11 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Implementation of a container frame.
|
|
|
|
*/
|
|
|
|
class nsContainerFrame : public nsSplittableFrame
|
|
|
|
{
|
|
|
|
public:
|
1999-01-16 01:53:39 +03:00
|
|
|
// nsIFrame overrides
|
1998-11-10 09:05:32 +03:00
|
|
|
NS_IMETHOD SetInitialChildList(nsIPresContext& aPresContext,
|
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame* aChildList);
|
1999-02-10 05:25:01 +03:00
|
|
|
NS_IMETHOD FirstChild(nsIAtom* aListName, nsIFrame** aFirstChild) const;
|
1999-07-22 06:24:52 +04:00
|
|
|
NS_IMETHOD Destroy(nsIPresContext& aPresContext);
|
1998-10-01 01:01:11 +04:00
|
|
|
NS_IMETHOD Paint(nsIPresContext& aPresContext,
|
|
|
|
nsIRenderingContext& aRenderingContext,
|
1998-12-18 18:54:23 +03:00
|
|
|
const nsRect& aDirtyRect,
|
|
|
|
nsFramePaintLayer aWhichLayer);
|
1999-10-26 08:44:41 +04:00
|
|
|
NS_IMETHOD GetFrameForPoint(nsIPresContext* aPresContext,
|
|
|
|
const nsPoint& aPoint,
|
|
|
|
nsIFrame** aFrame);
|
1999-07-22 08:32:31 +04:00
|
|
|
NS_IMETHOD ReplaceFrame(nsIPresContext& aPresContext,
|
|
|
|
nsIPresShell& aPresShell,
|
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame* aOldFrame,
|
|
|
|
nsIFrame* aNewFrame);
|
1999-10-26 08:44:41 +04:00
|
|
|
NS_IMETHOD List(nsIPresContext* aPresContext, FILE* out, PRInt32 aIndent) const;
|
1999-09-01 05:02:16 +04:00
|
|
|
#ifdef DEBUG
|
1999-08-31 07:09:40 +04:00
|
|
|
NS_IMETHOD SizeOf(nsISizeOfHandler* aHandler, PRUint32* aResult) const;
|
1999-09-01 05:02:16 +04:00
|
|
|
#endif
|
1998-10-01 01:01:11 +04:00
|
|
|
|
1999-01-16 01:53:39 +03:00
|
|
|
// nsIHTMLReflow overrides
|
|
|
|
NS_IMETHOD DidReflow(nsIPresContext& aPresContext,
|
|
|
|
nsDidReflowStatus aStatus);
|
1998-11-03 23:23:15 +03:00
|
|
|
|
1999-01-16 01:53:39 +03:00
|
|
|
// nsContainerFrame methods
|
|
|
|
virtual void DeleteChildsNextInFlow(nsIPresContext& aPresContext,
|
|
|
|
nsIFrame* aChild);
|
1998-10-01 01:01:11 +04:00
|
|
|
|
1999-01-16 01:53:39 +03:00
|
|
|
static PRInt32 LengthOf(nsIFrame* aFrameList) {
|
|
|
|
nsFrameList tmp(aFrameList);
|
|
|
|
return tmp.GetLength();
|
|
|
|
}
|
1998-10-01 01:01:11 +04:00
|
|
|
|
|
|
|
protected:
|
1999-01-16 01:53:39 +03:00
|
|
|
nsContainerFrame();
|
|
|
|
~nsContainerFrame();
|
1998-10-01 01:01:11 +04:00
|
|
|
|
1999-10-26 08:44:41 +04:00
|
|
|
nsresult GetFrameForPointUsing(nsIPresContext* aPresContext,
|
|
|
|
const nsPoint& aPoint,
|
1998-11-19 21:09:03 +03:00
|
|
|
nsIAtom* aList,
|
|
|
|
nsIFrame** aFrame);
|
|
|
|
|
1998-12-18 18:54:23 +03:00
|
|
|
virtual void PaintChildren(nsIPresContext& aPresContext,
|
|
|
|
nsIRenderingContext& aRenderingContext,
|
|
|
|
const nsRect& aDirtyRect,
|
|
|
|
nsFramePaintLayer aWhichLayer);
|
1998-10-01 01:01:11 +04:00
|
|
|
|
1998-10-31 01:11:06 +03:00
|
|
|
virtual void PaintChild(nsIPresContext& aPresContext,
|
|
|
|
nsIRenderingContext& aRenderingContext,
|
|
|
|
const nsRect& aDirtyRect,
|
1998-12-18 18:54:23 +03:00
|
|
|
nsIFrame* aFrame,
|
|
|
|
nsFramePaintLayer aWhichLayer);
|
1998-10-31 01:11:06 +03:00
|
|
|
|
1998-10-01 01:01:11 +04:00
|
|
|
/**
|
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
|
|
|
|
1999-10-21 09:11:43 +04:00
|
|
|
/**
|
|
|
|
* Get the frames on the overflow list
|
|
|
|
*/
|
|
|
|
nsIFrame* GetOverflowFrames(nsIPresContext* aPresContext,
|
|
|
|
PRBool aRemoveProperty);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the overflow list
|
|
|
|
*/
|
|
|
|
nsresult SetOverflowFrames(nsIPresContext* aPresContext,
|
|
|
|
nsIFrame* aOverflowFrames);
|
|
|
|
|
1999-01-16 01:53:39 +03: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
|
|
|
|
*/
|
1999-10-21 09:11:43 +04:00
|
|
|
PRBool MoveOverflowToChildList(nsIPresContext* aPresContext);
|
1998-10-01 01:01:11 +04:00
|
|
|
|
1999-01-16 01:53:39 +03:00
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
*/
|
1999-10-21 09:11:43 +04:00
|
|
|
void PushChildren(nsIPresContext* aPresContext,
|
|
|
|
nsIFrame* aFromChild,
|
|
|
|
nsIFrame* aPrevSibling);
|
1998-10-01 01:01:11 +04:00
|
|
|
|
1999-01-16 01:53:39 +03:00
|
|
|
nsFrameList mFrames;
|
1998-10-01 01:01:11 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* nsContainerFrame_h___ */
|