2001-09-28 20:14:13 +00:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Version: NPL 1.1/GPL 2.0/LGPL 2.1
|
1998-04-13 20:24:54 +00:00
|
|
|
*
|
2001-09-28 20:14:13 +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/
|
1998-04-13 20:24:54 +00:00
|
|
|
*
|
2001-09-28 20:14:13 +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.
|
1998-04-13 20:24:54 +00:00
|
|
|
*
|
1999-11-06 03:40:37 +00:00
|
|
|
* The Original Code is mozilla.org code.
|
|
|
|
*
|
2001-09-28 20:14:13 +00:00
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* Netscape Communications Corporation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 1998
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
1999-11-06 03:40:37 +00:00
|
|
|
*
|
2001-09-28 20:14:13 +00:00
|
|
|
* Contributor(s):
|
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
* use your version of this file under the terms of the NPL, indicate your
|
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
|
|
|
* the terms of any one of the NPL, the GPL or the LGPL.
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
1998-04-13 20:24:54 +00:00
|
|
|
#ifndef nsHTMLParts_h___
|
|
|
|
#define nsHTMLParts_h___
|
|
|
|
|
|
|
|
#include "nscore.h"
|
|
|
|
#include "nsISupports.h"
|
2001-12-17 22:39:59 +00:00
|
|
|
#include "nsReflowType.h"
|
|
|
|
class nsHTMLReflowCommand;
|
1998-04-13 20:24:54 +00:00
|
|
|
class nsIArena;
|
|
|
|
class nsIAtom;
|
2000-05-10 13:13:39 +00:00
|
|
|
class nsINodeInfo;
|
1998-04-13 20:24:54 +00:00
|
|
|
class nsIContent;
|
2000-03-22 05:55:05 +00:00
|
|
|
class nsIContentIterator;
|
1998-04-13 20:24:54 +00:00
|
|
|
class nsIDocument;
|
2001-12-17 22:39:59 +00:00
|
|
|
class nsIFrame;
|
1998-04-13 20:24:54 +00:00
|
|
|
class nsIHTMLContent;
|
|
|
|
class nsIHTMLContentSink;
|
1999-06-03 22:30:12 +00:00
|
|
|
class nsIHTMLFragmentContentSink;
|
2000-03-22 05:55:05 +00:00
|
|
|
class nsIPresContext;
|
1998-04-13 20:24:54 +00:00
|
|
|
class nsITextContent;
|
1999-06-23 03:29:44 +00:00
|
|
|
class nsIURI;
|
1998-04-13 20:24:54 +00:00
|
|
|
class nsString;
|
1998-07-18 21:47:56 +00:00
|
|
|
class nsIWebShell;
|
1999-12-04 23:49:50 +00:00
|
|
|
class nsIPresShell;
|
2001-03-03 00:41:02 +00:00
|
|
|
class nsIChannel;
|
1998-04-13 20:24:54 +00:00
|
|
|
|
2001-02-23 12:42:12 +00:00
|
|
|
/**
|
|
|
|
* Additional frame-state bits used by nsBlockFrame
|
|
|
|
* See the meanings at http://www.mozilla.org/newlayout/doc/block-and-line.html
|
|
|
|
*/
|
|
|
|
#define NS_BLOCK_FRAME_HAS_OUTSIDE_BULLET 0x40000000
|
|
|
|
#define NS_BLOCK_HAS_FIRST_LETTER_STYLE 0x20000000
|
|
|
|
#define NS_BLOCK_SHRINK_WRAP 0x00100000
|
|
|
|
#define NS_BLOCK_NO_AUTO_MARGINS 0x00200000
|
|
|
|
#define NS_BLOCK_MARGIN_ROOT 0x00400000
|
|
|
|
#define NS_BLOCK_SPACE_MGR 0x00800000
|
|
|
|
#define NS_BLOCK_WRAP_SIZE 0x01000000
|
|
|
|
#define NS_BLOCK_FLAGS_MASK 0xFFF00000
|
|
|
|
|
2000-03-22 05:55:05 +00:00
|
|
|
// Factory method for creating a content iterator for generated
|
|
|
|
// content
|
|
|
|
extern nsresult
|
2001-09-12 20:19:41 +00:00
|
|
|
NS_NewFrameContentIterator(nsIPresContext* aPresContext,
|
|
|
|
nsIFrame* aFrame,
|
|
|
|
nsIContentIterator** aIterator);
|
2000-03-22 05:55:05 +00:00
|
|
|
|
1998-09-04 00:55:20 +00:00
|
|
|
/**
|
|
|
|
* Create a new content object for the given tag.
|
|
|
|
* Returns NS_ERROR_NOT_AVAILABLE for an unknown/unhandled tag.
|
|
|
|
* Returns some other error on error.
|
|
|
|
* Returns NS_OK on success
|
|
|
|
*/
|
1999-02-09 00:26:50 +00:00
|
|
|
PR_EXTERN(nsresult)
|
1998-09-04 00:55:20 +00:00
|
|
|
NS_CreateHTMLElement(nsIHTMLContent** aResult,
|
2001-05-12 05:10:48 +00:00
|
|
|
nsINodeInfo *aNodeInfo,
|
2001-05-12 07:12:33 +00:00
|
|
|
PRBool aCaseSensitive);
|
1998-09-04 00:55:20 +00:00
|
|
|
|
1998-09-01 01:33:19 +00:00
|
|
|
// Factory methods for creating html layout objects
|
|
|
|
|
1999-05-11 22:03:29 +00:00
|
|
|
// These are variations on AreaFrame with slightly different layout
|
|
|
|
// policies.
|
1998-10-06 00:40:54 +00:00
|
|
|
|
1999-10-08 04:32:46 +00:00
|
|
|
// Create a frame that supports "display: block" layout behavior
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewBlockFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame,
|
1999-10-08 04:32:46 +00:00
|
|
|
PRUint32 aFlags = 0);
|
1999-05-11 22:03:29 +00:00
|
|
|
|
1999-08-19 14:32:19 +00:00
|
|
|
// Special Generated Content Frame
|
|
|
|
extern nsresult
|
|
|
|
NS_NewAttributeContent(nsIContent ** aResult);
|
|
|
|
|
1999-09-03 14:52:17 +00:00
|
|
|
// Create a basic area frame but the GetFrameForPoint is overridden to always
|
|
|
|
// return the option frame
|
|
|
|
// By default, area frames will extend
|
|
|
|
// their height to cover any children that "stick out".
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewSelectsAreaFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame,
|
1999-11-03 00:42:12 +00:00
|
|
|
PRUint32 aFlags = NS_BLOCK_WRAP_SIZE);
|
1999-08-19 14:32:19 +00:00
|
|
|
|
1999-05-11 22:03:29 +00:00
|
|
|
// Create a basic area frame. By default, area frames will extend
|
|
|
|
// their height to cover any children that "stick out".
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewAreaFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame,
|
1999-10-08 04:32:46 +00:00
|
|
|
PRUint32 aFlags = NS_BLOCK_SPACE_MGR|NS_BLOCK_WRAP_SIZE);
|
1999-05-11 22:03:29 +00:00
|
|
|
|
|
|
|
// These AreaFrame's shrink wrap around their contents
|
1999-12-04 23:49:50 +00:00
|
|
|
inline nsresult NS_NewTableCellInnerFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame) {
|
2000-02-11 15:31:41 +00:00
|
|
|
return NS_NewBlockFrame(aPresShell, aNewFrame,
|
|
|
|
NS_BLOCK_SPACE_MGR|NS_BLOCK_WRAP_SIZE|NS_BLOCK_MARGIN_ROOT);
|
1999-05-11 22:03:29 +00:00
|
|
|
}
|
|
|
|
|
1999-10-08 04:32:46 +00:00
|
|
|
// This type of AreaFrame is the document root, a margin root, and the
|
|
|
|
// initial containing block for absolutely positioned elements
|
1999-12-04 23:49:50 +00:00
|
|
|
inline nsresult NS_NewDocumentElementFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame) {
|
|
|
|
return NS_NewAreaFrame(aPresShell, aNewFrame, NS_BLOCK_SPACE_MGR|NS_BLOCK_MARGIN_ROOT);
|
1999-05-11 22:03:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// This type of AreaFrame is a margin root, but does not shrink wrap
|
1999-12-04 23:49:50 +00:00
|
|
|
inline nsresult NS_NewAbsoluteItemWrapperFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame) {
|
|
|
|
return NS_NewAreaFrame(aPresShell, aNewFrame, NS_BLOCK_SPACE_MGR|NS_BLOCK_MARGIN_ROOT);
|
1999-05-11 22:03:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// This type of AreaFrame shrink wraps
|
1999-12-04 23:49:50 +00:00
|
|
|
inline nsresult NS_NewFloatingItemWrapperFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame) {
|
|
|
|
return NS_NewAreaFrame(aPresShell, aNewFrame, NS_BLOCK_SPACE_MGR|NS_BLOCK_SHRINK_WRAP);
|
1999-05-11 22:03:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// This type of AreaFrame doesn't use its own space manager and
|
|
|
|
// doesn't shrink wrap.
|
1999-12-04 23:49:50 +00:00
|
|
|
inline nsresult NS_NewRelativeItemWrapperFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame) {
|
|
|
|
return NS_NewAreaFrame(aPresShell, aNewFrame);
|
1999-05-11 22:03:29 +00:00
|
|
|
}
|
|
|
|
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewBRFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
1999-05-11 22:03:29 +00:00
|
|
|
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewCommentFrame(nsIPresShell* aPresShell, nsIFrame** aFrameResult);
|
|
|
|
extern nsresult NS_NewHRFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
1998-09-06 00:17:30 +00:00
|
|
|
|
1998-09-09 23:30:30 +00:00
|
|
|
// <frame> and <iframe>
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewHTMLFrameOuterFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
1998-09-09 23:30:30 +00:00
|
|
|
// <frameset>
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewHTMLFramesetFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
|
|
|
|
|
|
|
extern nsresult NS_NewViewportFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
2000-04-19 02:13:43 +00:00
|
|
|
extern nsresult NS_NewCanvasFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewImageFrame(nsIPresShell* aPresShell, nsIFrame** aFrameResult);
|
|
|
|
extern nsresult NS_NewInlineFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
|
|
|
extern nsresult NS_NewPositionedInlineFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
|
|
|
extern nsresult NS_NewObjectFrame(nsIPresShell* aPresShell, nsIFrame** aFrameResult);
|
|
|
|
extern nsresult NS_NewSpacerFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewTextFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewContinuingTextFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewEmptyFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
inline nsresult NS_NewWBRFrame(nsIPresShell* aPresShell, nsIFrame** aResult) {
|
|
|
|
return NS_NewEmptyFrame(aPresShell, aResult);
|
1999-05-11 22:03:29 +00:00
|
|
|
}
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewScrollFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewSimplePageSequenceFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewPageFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
2002-01-25 14:30:14 +00:00
|
|
|
extern nsresult NS_NewPageContentFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
2002-03-17 21:35:08 +00:00
|
|
|
extern nsresult NS_NewPageBreakFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewFirstLetterFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
|
|
|
extern nsresult NS_NewFirstLineFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
1998-10-12 22:13:23 +00:00
|
|
|
|
1998-09-23 17:16:51 +00:00
|
|
|
// forms
|
1999-12-08 02:07:03 +00:00
|
|
|
extern nsresult NS_NewFormFrame(nsIPresShell* aPresShell, nsIFrame** aResult, PRUint32 aFlags);
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewGfxButtonControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewNativeButtonControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewImageControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewHTMLButtonControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewGfxCheckboxControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewNativeCheckboxControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
2000-01-18 15:38:50 +00:00
|
|
|
extern nsresult NS_NewFieldSetFrame(nsIPresShell* aPresShell, nsIFrame** aResult, PRUint32 aFlags);
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewFileControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
2000-03-27 22:12:16 +00:00
|
|
|
extern nsresult NS_NewLabelFrame(nsIPresShell* aPresShell, nsIFrame** aResult, PRUint32 aStateFlags);
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewLegendFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewNativeTextControlFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
|
|
|
extern nsresult NS_NewGfxTextControlFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
|
|
|
extern nsresult NS_NewGfxAutoTextControlFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
|
|
|
extern nsresult NS_NewGfxRadioControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewNativeRadioControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewNativeSelectControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewListControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
1999-12-05 20:43:19 +00:00
|
|
|
extern nsresult NS_NewComboboxControlFrame(nsIPresShell* aPresShell, nsIFrame** aResult, PRUint32 aFlags);
|
2000-09-14 04:43:31 +00:00
|
|
|
extern nsresult NS_NewIsIndexFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
1999-05-11 22:03:29 +00:00
|
|
|
|
|
|
|
// Table frame factories
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewTableOuterFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewTableFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
2000-01-28 02:19:45 +00:00
|
|
|
extern nsresult NS_NewTableCaptionFrame(nsIPresShell* aPresShell, nsIFrame** aNewFrame);
|
|
|
|
|
1999-12-04 23:49:50 +00:00
|
|
|
extern nsresult NS_NewTableColFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewTableColGroupFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewTableRowFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
|
|
|
extern nsresult NS_NewTableRowGroupFrame(nsIPresShell* aPresShell, nsIFrame** aResult);
|
2002-02-19 15:48:28 +00:00
|
|
|
extern nsresult NS_NewTableCellFrame(nsIPresShell* aPresShell, PRBool aIsBorderCollapse, nsIFrame** aResult);
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-07-18 21:47:56 +00:00
|
|
|
// XXX passing aWebShell into this is wrong
|
1998-04-13 20:24:54 +00:00
|
|
|
extern nsresult NS_NewHTMLContentSink(nsIHTMLContentSink** aInstancePtrResult,
|
|
|
|
nsIDocument* aDoc,
|
1999-06-23 03:29:44 +00:00
|
|
|
nsIURI* aURL,
|
2001-03-03 00:41:02 +00:00
|
|
|
nsIWebShell* aWebShell,
|
|
|
|
nsIChannel* aChannel);
|
1999-06-03 22:30:12 +00:00
|
|
|
extern nsresult NS_NewHTMLFragmentContentSink(nsIHTMLFragmentContentSink** aInstancePtrResult);
|
1998-04-13 20:24:54 +00:00
|
|
|
|
1998-06-09 04:51:44 +00:00
|
|
|
/** Create a new HTML reflow command */
|
|
|
|
extern nsresult
|
2001-12-17 22:39:59 +00:00
|
|
|
NS_NewHTMLReflowCommand(nsHTMLReflowCommand** aInstancePtrResult,
|
|
|
|
nsIFrame* aTargetFrame,
|
|
|
|
nsReflowType aReflowType,
|
|
|
|
nsIFrame* aChildFrame = nsnull,
|
|
|
|
nsIAtom* aAttribute = nsnull);
|
1998-06-09 04:51:44 +00:00
|
|
|
|
1998-04-13 20:24:54 +00:00
|
|
|
#endif /* nsHTMLParts_h___ */
|