1999-04-20 00:23:05 +00:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
|
|
*
|
1999-11-06 03:40:37 +00:00
|
|
|
* The contents of this file are subject to the Netscape Public
|
|
|
|
* License Version 1.1 (the "License"); you may not use this file
|
|
|
|
* except in compliance with the License. You may obtain a copy of
|
|
|
|
* the License at http://www.mozilla.org/NPL/
|
1999-04-20 00:23:05 +00:00
|
|
|
*
|
1999-11-06 03:40:37 +00:00
|
|
|
* Software distributed under the License is distributed on an "AS
|
|
|
|
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
|
|
|
|
* implied. See the License for the specific language governing
|
|
|
|
* rights and limitations under the License.
|
1999-04-20 00:23:05 +00:00
|
|
|
*
|
|
|
|
* The Original Code is Mozilla Communicator client code.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Netscape Communications
|
1999-11-06 03:40:37 +00:00
|
|
|
* Corporation. Portions created by Netscape are
|
|
|
|
* Copyright (C) 1998 Netscape Communications Corporation. All
|
|
|
|
* Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
1999-04-20 00:23:05 +00:00
|
|
|
*/
|
|
|
|
#ifndef nsInlineFrame_h___
|
|
|
|
#define nsInlineFrame_h___
|
|
|
|
|
|
|
|
#include "nsHTMLContainerFrame.h"
|
|
|
|
#include "nsAbsoluteContainingBlock.h"
|
|
|
|
#include "nsLineLayout.h"
|
|
|
|
|
|
|
|
class nsAnonymousBlockFrame;
|
|
|
|
|
1999-07-14 17:28:45 +00:00
|
|
|
#define NS_INLINE_FRAME_CID \
|
|
|
|
{ 0xa6cf90e0, 0x15b3, 0x11d2,{0x93, 0x2e, 0x00, 0x80, 0x5f, 0x8a, 0xdd, 0x32}}
|
|
|
|
|
1999-04-20 00:23:05 +00:00
|
|
|
#define nsInlineFrameSuper nsHTMLContainerFrame
|
|
|
|
|
2001-02-23 12:42:12 +00:00
|
|
|
#define NS_INLINE_FRAME_CONTAINS_PERCENT_AWARE_CHILD 0x00100000
|
2000-09-11 20:46:44 +00:00
|
|
|
|
1999-11-01 15:24:57 +00:00
|
|
|
/**
|
|
|
|
* Inline frame class.
|
|
|
|
*
|
|
|
|
* This class manages a list of child frames that are inline frames. Working with
|
|
|
|
* nsLineLayout, the class will reflow and place inline frames on a line.
|
|
|
|
*/
|
1999-04-20 00:23:05 +00:00
|
|
|
class nsInlineFrame : public nsInlineFrameSuper
|
|
|
|
{
|
|
|
|
public:
|
1999-12-04 23:49:50 +00:00
|
|
|
friend nsresult NS_NewInlineFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
1999-04-20 00:23:05 +00:00
|
|
|
|
|
|
|
// nsISupports overrides
|
|
|
|
NS_IMETHOD QueryInterface(const nsIID& aIID, void** aInstancePtr);
|
|
|
|
|
|
|
|
// nsIFrame overrides
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD AppendFrames(nsIPresContext* aPresContext,
|
1999-04-20 00:23:05 +00:00
|
|
|
nsIPresShell& aPresShell,
|
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame* aFrameList);
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD InsertFrames(nsIPresContext* aPresContext,
|
1999-04-20 00:23:05 +00:00
|
|
|
nsIPresShell& aPresShell,
|
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame* aPrevFrame,
|
|
|
|
nsIFrame* aFrameList);
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD RemoveFrame(nsIPresContext* aPresContext,
|
1999-04-20 00:23:05 +00:00
|
|
|
nsIPresShell& aPresShell,
|
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame* aOldFrame);
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD ReplaceFrame(nsIPresContext* aPresContext,
|
1999-11-01 15:24:57 +00:00
|
|
|
nsIPresShell& aPresShell,
|
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame* aOldFrame,
|
|
|
|
nsIFrame* aNewFrame);
|
2000-01-12 21:52:58 +00:00
|
|
|
NS_IMETHOD ReflowDirtyChild(nsIPresShell* aPresShell, nsIFrame* aChild);
|
|
|
|
|
1999-11-01 22:12:45 +00:00
|
|
|
#ifdef DEBUG
|
1999-04-20 00:23:05 +00:00
|
|
|
NS_IMETHOD GetFrameName(nsString& aResult) const;
|
1999-11-01 22:12:45 +00:00
|
|
|
#endif
|
1999-04-20 00:23:05 +00:00
|
|
|
NS_IMETHOD GetFrameType(nsIAtom** aType) const;
|
|
|
|
|
|
|
|
// nsIHTMLReflow overrides
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD Reflow(nsIPresContext* aPresContext,
|
1999-04-20 00:23:05 +00:00
|
|
|
nsHTMLReflowMetrics& aDesiredSize,
|
|
|
|
const nsHTMLReflowState& aReflowState,
|
|
|
|
nsReflowStatus& aStatus);
|
|
|
|
|
2000-07-28 22:29:28 +00:00
|
|
|
NS_IMETHOD CanContinueTextRun(PRBool& aContinueTextRun) const;
|
|
|
|
|
1999-07-14 17:28:45 +00:00
|
|
|
static nsIID kInlineFrameCID;
|
|
|
|
|
1999-11-01 15:24:57 +00:00
|
|
|
// Take all of the frames away from this frame. The caller is
|
|
|
|
// presumed to keep them alive.
|
|
|
|
void StealAllFrames() {
|
|
|
|
mFrames.SetFrames(nsnull);
|
|
|
|
}
|
|
|
|
|
1999-04-20 00:23:05 +00:00
|
|
|
protected:
|
|
|
|
// Additional reflow state used during our reflow methods
|
|
|
|
struct InlineReflowState {
|
|
|
|
nsIFrame* mNextRCFrame;
|
|
|
|
nsIFrame* mPrevFrame;
|
|
|
|
nsInlineFrame* mNextInFlow;
|
2000-09-11 20:46:44 +00:00
|
|
|
PRPackedBool mSetParentPointer; // when reflowing child frame first set its
|
|
|
|
// parent frame pointer
|
2000-03-20 23:47:01 +00:00
|
|
|
|
|
|
|
InlineReflowState() {
|
|
|
|
mNextRCFrame = nsnull;
|
|
|
|
mPrevFrame = nsnull;
|
|
|
|
mNextInFlow = nsnull;
|
2000-03-22 04:06:37 +00:00
|
|
|
mSetParentPointer = PR_FALSE;
|
2000-03-20 23:47:01 +00:00
|
|
|
};
|
1999-04-20 00:23:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
nsInlineFrame();
|
|
|
|
|
|
|
|
virtual PRIntn GetSkipSides() const;
|
|
|
|
|
1999-11-01 15:24:57 +00:00
|
|
|
nsresult ReflowFrames(nsIPresContext* aPresContext,
|
|
|
|
const nsHTMLReflowState& aReflowState,
|
|
|
|
InlineReflowState& rs,
|
|
|
|
nsHTMLReflowMetrics& aMetrics,
|
|
|
|
nsReflowStatus& aStatus);
|
1999-04-20 00:23:05 +00:00
|
|
|
|
|
|
|
nsresult ReflowInlineFrame(nsIPresContext* aPresContext,
|
|
|
|
const nsHTMLReflowState& aReflowState,
|
|
|
|
InlineReflowState& rs,
|
|
|
|
nsIFrame* aFrame,
|
|
|
|
nsReflowStatus& aStatus);
|
|
|
|
|
1999-11-01 15:24:57 +00:00
|
|
|
virtual nsIFrame* PullOneFrame(nsIPresContext* aPresContext,
|
|
|
|
InlineReflowState& rs,
|
|
|
|
PRBool* aIsComplete);
|
1999-04-20 00:23:05 +00:00
|
|
|
|
|
|
|
virtual void PushFrames(nsIPresContext* aPresContext,
|
|
|
|
nsIFrame* aFromChild,
|
|
|
|
nsIFrame* aPrevSibling);
|
2000-09-11 20:46:44 +00:00
|
|
|
|
1999-04-20 00:23:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
|
1999-11-01 15:24:57 +00:00
|
|
|
/**
|
|
|
|
* Variation on inline-frame used to manage lines for line layout in
|
|
|
|
* special situations (:first-line style in particular).
|
|
|
|
*/
|
1999-04-20 00:23:05 +00:00
|
|
|
class nsFirstLineFrame : public nsInlineFrame {
|
|
|
|
public:
|
1999-12-04 23:49:50 +00:00
|
|
|
friend nsresult NS_NewFirstLineFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
1999-04-20 00:23:05 +00:00
|
|
|
|
1999-11-01 23:12:32 +00:00
|
|
|
#ifdef DEBUG
|
1999-04-20 00:23:05 +00:00
|
|
|
NS_IMETHOD GetFrameName(nsString& aResult) const;
|
1999-11-01 23:12:32 +00:00
|
|
|
#endif
|
1999-04-20 00:23:05 +00:00
|
|
|
NS_IMETHOD GetFrameType(nsIAtom** aType) const;
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD Reflow(nsIPresContext* aPresContext,
|
1999-04-20 00:23:05 +00:00
|
|
|
nsHTMLReflowMetrics& aDesiredSize,
|
|
|
|
const nsHTMLReflowState& aReflowState,
|
|
|
|
nsReflowStatus& aStatus);
|
|
|
|
|
1999-08-31 03:09:40 +00:00
|
|
|
// Take frames starting at aFrame until the end of the frame-list
|
|
|
|
// away from this frame. The caller is presumed to keep them alive.
|
|
|
|
void StealFramesFrom(nsIFrame* aFrame);
|
1999-04-20 00:23:05 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
nsFirstLineFrame();
|
|
|
|
|
1999-11-01 15:24:57 +00:00
|
|
|
virtual nsIFrame* PullOneFrame(nsIPresContext* aPresContext,
|
|
|
|
InlineReflowState& rs,
|
|
|
|
PRBool* aIsComplete);
|
1999-04-20 00:23:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------
|
|
|
|
|
|
|
|
// Derived class created for relatively positioned inline-level elements
|
|
|
|
// that acts as a containing block for child absolutely positioned
|
|
|
|
// elements
|
|
|
|
|
|
|
|
class nsPositionedInlineFrame : public nsInlineFrame
|
|
|
|
{
|
|
|
|
public:
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD Destroy(nsIPresContext* aPresContext);
|
1999-09-01 01:02:16 +00:00
|
|
|
#ifdef DEBUG
|
1999-08-31 03:09:40 +00:00
|
|
|
NS_IMETHOD SizeOf(nsISizeOfHandler* aHandler, PRUint32* aResult) const;
|
1999-09-01 01:02:16 +00:00
|
|
|
#endif
|
1999-04-20 00:23:05 +00:00
|
|
|
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD SetInitialChildList(nsIPresContext* aPresContext,
|
1999-04-20 00:23:05 +00:00
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame* aChildList);
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD AppendFrames(nsIPresContext* aPresContext,
|
1999-04-21 04:37:13 +00:00
|
|
|
nsIPresShell& aPresShell,
|
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame* aFrameList);
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD InsertFrames(nsIPresContext* aPresContext,
|
1999-04-21 04:37:13 +00:00
|
|
|
nsIPresShell& aPresShell,
|
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame* aPrevFrame,
|
|
|
|
nsIFrame* aFrameList);
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD RemoveFrame(nsIPresContext* aPresContext,
|
1999-04-21 04:37:13 +00:00
|
|
|
nsIPresShell& aPresShell,
|
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame* aOldFrame);
|
1999-04-20 00:23:05 +00:00
|
|
|
|
|
|
|
NS_IMETHOD GetAdditionalChildListName(PRInt32 aIndex,
|
|
|
|
nsIAtom** aListName) const;
|
|
|
|
|
2000-01-22 01:16:50 +00:00
|
|
|
NS_IMETHOD FirstChild(nsIPresContext* aPresContext,
|
|
|
|
nsIAtom* aListName,
|
|
|
|
nsIFrame** aFirstChild) const;
|
1999-04-20 00:23:05 +00:00
|
|
|
|
1999-11-24 06:03:41 +00:00
|
|
|
NS_IMETHOD Reflow(nsIPresContext* aPresContext,
|
1999-04-20 00:23:05 +00:00
|
|
|
nsHTMLReflowMetrics& aDesiredSize,
|
|
|
|
const nsHTMLReflowState& aReflowState,
|
|
|
|
nsReflowStatus& aStatus);
|
1999-04-20 19:11:37 +00:00
|
|
|
|
|
|
|
NS_IMETHOD GetFrameType(nsIAtom** aType) const;
|
1999-04-20 00:23:05 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
nsAbsoluteContainingBlock mAbsoluteContainer;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* nsInlineFrame_h___ */
|