mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-11 14:28:42 +00:00
252 lines
10 KiB
C++
252 lines
10 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
*
|
|
* The contents of this file are subject to the Mozilla 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/MPL/
|
|
*
|
|
* 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.
|
|
*
|
|
* The Original Code is mozilla.org code.
|
|
*
|
|
* 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.
|
|
*
|
|
* Contributor(s):
|
|
*
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
* either of 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 MPL, 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 MPL, the GPL or the LGPL.
|
|
*
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
/* factory functions for rendering object classes */
|
|
|
|
#ifndef nsHTMLParts_h___
|
|
#define nsHTMLParts_h___
|
|
|
|
#include "nscore.h"
|
|
#include "nsISupports.h"
|
|
#include "nsIFrame.h"
|
|
class nsIAtom;
|
|
class nsNodeInfoManager;
|
|
class nsIContent;
|
|
class nsIContentIterator;
|
|
class nsIDocument;
|
|
class nsIFrame;
|
|
class nsIHTMLContentSink;
|
|
class nsIFragmentContentSink;
|
|
class nsStyleContext;
|
|
class nsIURI;
|
|
class nsString;
|
|
class nsIPresShell;
|
|
class nsIChannel;
|
|
class nsTableColFrame;
|
|
|
|
/**
|
|
* Additional frame-state bits used by nsBlockFrame
|
|
* See the meanings at http://www.mozilla.org/newlayout/doc/block-and-line.html
|
|
*
|
|
* NS_BLOCK_CLIP_PAGINATED_OVERFLOW is only set in paginated prescontexts, on
|
|
* blocks which were forced to not have scrollframes but still need to clip
|
|
* the display of their kids.
|
|
*
|
|
* NS_BLOCK_HAS_FIRST_LETTER_STYLE means that the block has first-letter style,
|
|
* even if it has no actual first-letter frame among its descendants.
|
|
*
|
|
* NS_BLOCK_HAS_FIRST_LETTER_CHILD means that there is an inflow first-letter
|
|
* frame among the block's descendants. If there is a floating first-letter
|
|
* frame, or the block has first-letter style but has no first letter, this
|
|
* bit is not set. This bit is set on the first continuation only.
|
|
*
|
|
* NS_BLOCK_FRAME_HAS_OUTSIDE_BULLET and NS_BLOCK_FRAME_HAS_INSIDE_BULLET
|
|
* means the block has an associated bullet frame, they are mutually exclusive.
|
|
*
|
|
*/
|
|
#define NS_BLOCK_MARGIN_ROOT NS_FRAME_STATE_BIT(22)
|
|
#define NS_BLOCK_FLOAT_MGR NS_FRAME_STATE_BIT(23)
|
|
#define NS_BLOCK_CLIP_PAGINATED_OVERFLOW NS_FRAME_STATE_BIT(28)
|
|
#define NS_BLOCK_HAS_FIRST_LETTER_STYLE NS_FRAME_STATE_BIT(29)
|
|
#define NS_BLOCK_FRAME_HAS_OUTSIDE_BULLET NS_FRAME_STATE_BIT(30)
|
|
#define NS_BLOCK_HAS_FIRST_LETTER_CHILD NS_FRAME_STATE_BIT(31)
|
|
#define NS_BLOCK_FRAME_HAS_INSIDE_BULLET NS_FRAME_STATE_BIT(63)
|
|
// These are all the block specific frame bits, they are copied from
|
|
// the prev-in-flow to a newly created next-in-flow, except for the
|
|
// NS_BLOCK_FLAGS_NON_INHERITED_MASK bits below.
|
|
#define NS_BLOCK_FLAGS_MASK (NS_BLOCK_MARGIN_ROOT | \
|
|
NS_BLOCK_FLOAT_MGR | \
|
|
NS_BLOCK_CLIP_PAGINATED_OVERFLOW | \
|
|
NS_BLOCK_HAS_FIRST_LETTER_STYLE | \
|
|
NS_BLOCK_FRAME_HAS_OUTSIDE_BULLET | \
|
|
NS_BLOCK_HAS_FIRST_LETTER_CHILD | \
|
|
NS_BLOCK_FRAME_HAS_INSIDE_BULLET)
|
|
|
|
// This is the subset of NS_BLOCK_FLAGS_MASK that is NOT inherited
|
|
// by default. They should only be set on the first-in-flow.
|
|
// See nsBlockFrame::Init.
|
|
#define NS_BLOCK_FLAGS_NON_INHERITED_MASK \
|
|
(NS_BLOCK_FRAME_HAS_OUTSIDE_BULLET | \
|
|
NS_BLOCK_HAS_FIRST_LETTER_CHILD | \
|
|
NS_BLOCK_FRAME_HAS_INSIDE_BULLET)
|
|
|
|
// Factory methods for creating html layout objects
|
|
|
|
// Create a frame that supports "display: block" layout behavior
|
|
nsIFrame*
|
|
NS_NewBlockFrame(nsIPresShell* aPresShell, nsStyleContext* aContext, PRUint32 aFlags = 0);
|
|
|
|
// Special Generated Content Node. It contains text taken from an
|
|
// attribute of its *grandparent* content node.
|
|
nsresult
|
|
NS_NewAttributeContent(nsNodeInfoManager *aNodeInfoManager,
|
|
PRInt32 aNameSpaceID, nsIAtom* aAttrName,
|
|
nsIContent** aResult);
|
|
|
|
// 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".
|
|
nsIFrame*
|
|
NS_NewSelectsAreaFrame(nsIPresShell* aPresShell, nsStyleContext* aContext, PRUint32 aFlags);
|
|
|
|
// Create a block formatting context blockframe
|
|
inline nsIFrame* NS_NewBlockFormattingContext(nsIPresShell* aPresShell,
|
|
nsStyleContext* aStyleContext)
|
|
{
|
|
return NS_NewBlockFrame(aPresShell, aStyleContext,
|
|
NS_BLOCK_FLOAT_MGR | NS_BLOCK_MARGIN_ROOT);
|
|
}
|
|
|
|
nsIFrame*
|
|
NS_NewBRFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
|
|
nsIFrame*
|
|
NS_NewCommentFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
|
|
// <frame> and <iframe>
|
|
nsIFrame*
|
|
NS_NewSubDocumentFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
// <frameset>
|
|
nsIFrame*
|
|
NS_NewHTMLFramesetFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
|
|
nsIFrame*
|
|
NS_NewViewportFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewCanvasFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewImageFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewInlineFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewObjectFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewTextFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewContinuingTextFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewEmptyFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
inline nsIFrame*
|
|
NS_NewWBRFrame(nsIPresShell* aPresShell, nsStyleContext* aContext) {
|
|
return NS_NewEmptyFrame(aPresShell, aContext);
|
|
}
|
|
|
|
nsIFrame*
|
|
NS_NewColumnSetFrame(nsIPresShell* aPresShell, nsStyleContext* aContext, PRUint32 aStateFlags);
|
|
|
|
nsIFrame*
|
|
NS_NewSimplePageSequenceFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewPageFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewPageContentFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewPageBreakFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewFirstLetterFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewFirstLineFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
|
|
// forms
|
|
nsIFrame*
|
|
NS_NewGfxButtonControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewNativeButtonControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewImageControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewHTMLButtonControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewGfxCheckboxControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewNativeCheckboxControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewFieldSetFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewFileControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewLegendFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewNativeTextControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewTextControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewGfxAutoTextControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewGfxRadioControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewNativeRadioControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewNativeSelectControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewListControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewComboboxControlFrame(nsIPresShell* aPresShell, nsStyleContext* aContext, PRUint32 aFlags);
|
|
nsIFrame*
|
|
NS_NewProgressFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
|
|
// Table frame factories
|
|
nsIFrame*
|
|
NS_NewTableOuterFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewTableFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewTableCaptionFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsTableColFrame*
|
|
NS_NewTableColFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewTableColGroupFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewTableRowFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewTableRowGroupFrame(nsIPresShell* aPresShell, nsStyleContext* aContext);
|
|
nsIFrame*
|
|
NS_NewTableCellFrame(nsIPresShell* aPresShell, nsStyleContext* aContext, bool aIsBorderCollapse);
|
|
|
|
nsresult
|
|
NS_NewHTMLContentSink(nsIHTMLContentSink** aInstancePtrResult,
|
|
nsIDocument* aDoc, nsIURI* aURL,
|
|
nsISupports* aContainer, // e.g. docshell
|
|
nsIChannel* aChannel);
|
|
nsresult
|
|
NS_NewHTMLFragmentContentSink(nsIFragmentContentSink** aInstancePtrResult);
|
|
nsresult
|
|
NS_NewHTMLFragmentContentSink2(nsIFragmentContentSink** aInstancePtrResult);
|
|
|
|
#endif /* nsHTMLParts_h___ */
|