mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 22:53:04 +00:00
4696208ad8
- Bug 1258627 - always schedule next cycle so MDSM has a chance to leave buffering state. r=cpearce. (49fb876b9e) - Bug 1258271 - Remove arguments from MediaDecoderStateMachine::HaveEnoughDecodedAudio(). r=bechen. (e8610f7f76) - Bug 1252753. Part 1 - remove calls to PushFront(). r=kinetik. (7abe1bfb0f) - Bug 1252753. Part 2 - remove MediaDecoderStateMachine::PushFront(). r=kinetik. (1a153a5b00) - Bug 1230527: P1. Ensure seeked event is fired prior loadeddata. r=jwwang (aa9eef9fd3) - Bug 1230527: P2. Add mochitest. r=jwwang (6e9f920781) - Bug 1252767 - Remove MediaDecoderStateMachine::mPendingSeek. r=cpearce. (e5d69a191d) - Bug 1255268 - Replace SeekJob::Steal() with move semantics. r=cpearce. (6294c01ba7) - Bug 1253490 - fix the calculation of decodeTime. r=jya. (b8f3c8801a) - Bug 1252343. Part 1 - make mReader const. r=bechen. (33a8b6a4ad) - Bug 1252343. Part 2 - remove null checks for mReader which is const and never null. r=bechen. (5cd068aafc) - Bug 1250054. Part 2 - employ MediaDecoderReaderWrapper for MDSM and remove code about adjusting start time. r=jya. (b5a954d8d8) - Bug 1252341 - No need to reset mReader in ~MediaDecoderStateMachine() because the destructor will do that. r=bechen. (cd0639e366) - Bug 1264784 - part 2 - remove unused virtual methods from nsIFrame; r=dholbert (5d52314a79) - Bug 1264784 - part 3 - make nsIFrame::GetNearestWidget methods non-virtual; r=dholbert (67b0987de6) - Bug 1053986 - Rename nsIFrame::IsBoxFrame to IsXULBoxFrame. r=dholbert (394613f49f) - Bug 1256040 - Fix some nsGridContainerFrame.h/cpp compile errors in non-unified build. r=dholbert (b49241e3b1) - Bug 1264607 - Treat track size <percentage> values as 'auto' when the grid container size is indefinite. r=dholbert (3895d4d922) - Bug 1260614 - Cleanup grid item iterator Reset() calls. r=dholbert (e6760e1def) - Bug 1256040 - Bustage fix. r=me (d67b9c0de5) - Bug 1233191 part 1 - Implement sanity checks on the flex/grid container child frame list. Remove the anon grid item sanity checks that the frame constructor now does instead. r=dholbert (d9412bb043) - Bug 1233191 part 2 - Remove anon flex item sanity checks that the frame constructor now does instead. r=dholbert (564184ea6d) - Bug 1233191 part 3 - crashtest. (c6b6bb4fca) - Bug 1187846 Stack layout doesn't honour min/max sizes for positioned elements r=Enn (8080e9db71) - Bug 1053986 - Rename nsIFrame::GetMinSize to GetXULMinSize, and related methods. r=dholbert (fa1722982e) - Bug 1000870 - Add some features in testing system. r=smaug (f7b4b8916f) - Bug 1053986 - Rename nsIFrame::GetPrefSize to GetXULPrefSize, and related methods. r=dholbert (9f7e8de26e) - Bug 1053986 - Rename nsIFrame::GetMaxSize to GetXULMaxSize, and related methods. r=dholbert (a632913886) - Bug 1053986 - Rename nsIFrame::GetMinSizeForScrollArea to GetXULMinSizeForScrollArea. r=dholbert (ac520afe6f) - Bug 1053986 - Rename nsIFrame::GetOrdinal to GetXULOrdinal. r=dholbert (e5f7342d03) - Bug 1053986 - Rename nsIFrame::GetFlex to GetXULFlex. r=dholbert (aadf567a8c) - Bug 1053986 - Rename nsIFrame::GetBoxAscent to GetXULBoxAscent. r=dholbert (4e729c60ea) - Bug 1053986 - Rename nsFrame.cpp static method IsBoxWrapped to IsXULBoxWrapped. r=dholbert (009b251df0) - Bug 1053986 - Rename nsIFrame::IsCollapsed to IsXULCollapsed, and related methods. r=dholbert (eec509e378) - Bug 1168212 - Ensure popups have a minimum width of their preferred size r=Enn (657c8da6fa) - Bug 1053986 - Rename nsIFrame::SetBounds to SetXULBounds. r=dholbert (304ff47c6c) - Bug 1088637 - check we get the right transition event, r=Enn (b0da4a67f6) - Bug 1053986 - Rename nsIFrame::Layout to XULLayout, and related methods with the same name. r=dholbert (66ef396b10) - Bug 1053986 - Rename nsIFrame::GetBorderAndPadding to GetXULBorderAndPadding. r=dholbert (588f824000) - Bug 1053986 - Rename nsIFrame::GetBorder to GetXULBorder. r=dholbert (f91ae3fc59) - Bug 1053986 - Rename nsIFrame::GetPadding to GetXULPadding. r=dholbert (797e21e6af) - Bug 1053986 - Rename nsIFrame::GetMargin to GetXULMargin. r=dholbert (05dc0235f2) - Bug 1053986 - Rename nsIFrame::SetLayoutManager to SetXULLayoutManager. r=dholbert (0cb22c411d) - Bug 1053986 - Rename nsIFrame::GetLayoutManager to GetXULLayoutManager. r=dholbert (6a03e1de2c) - Bug 852754 - Part 1: Share the code for limiting scale factors to all image types. r=mstange (098a083d1a) - Bug 852754 - Part 2: Share the implementation of GetContainer. r=mstange (063b7683dd) - Bug 852754 - Part 3: Share the implementation of ConfigureLayer. r=mstange (ffd2d99802) - Bug 1256999 - Pass the right context to new channels for image loads. r=bz r=seth (275cebb231) - Bug 1194337 - Context menu positioned incorrectly on OSX. r=enn (1e429a9d3c) - Bug 1216284 - Tooltips do not flip correctly on OSX. r=enndeakin (c08931768b) - Bug 1053986 - Rename nsIFrame::GetClientRect to GetXULClientRect. r=dholbert (c06a121de6) - Bug 1053986 - Rename nsIFrame::GetVAlign to GetXULVAlign. r=dholbert (a923d76c4b) - Bug 1053986 - Rename nsBox::GetChildBox to GetChildXULBox. r=dholbert (ebe12c77f1) - Bug 1053986 - Rename nsIFrame::GetHAlign to GetXULHAlign. r=dholbert (dbd501e2bd) - Bug 1053986 - Rename nsBox::GetNextBox to GetNextXULBox. r=dholbert (1cd5fa1ce3) - Bug 1053986 - Rename nsBox::GetParentBox to GetParentXULBox. r=dholbert (2beaeb6bdd) - Bug 1171696 - Don't resize scrollbar thumb when updating its position. r=mstange (5b51241744) - Bug 1053986 - Rename nsIFrame::IsHorizontal to IsXULHorizontal, and related methods. r=dholbert (7d8e4142e5) - Bug 1053986 - Rename nsIFrame::IsNormalDirection to IsXULNormalDirection. r=dholbert (7d9686b089) - Bug 1053986 - Rename nsIFrame::Redraw to XULRedraw. r=dholbert (20da19c2ce) - Bug 1053986 - Rename nsIFrame::RelayoutChildAtOrdinal to XULRelayoutChildAtOrdinal. r=dholbert (e5c4eb2b9f) - Bug 1053986 - Rename nsIFrame::SetDebug to SetXULDebug. r=dholbert (438c3a1109) - Bug 1053986 - Rename nsIFrame::GetDebug to GetXULDebug. r=dholbert (00e0ca19e4) - Bug 1053986 - Rename nsIFrame::DumpBox to XULDumpBox. r=dholbert (30edc21d8e) - Bug 1053986 - Rename nsIFrame::AddCSSPrefSize, AddCSSMinSize, AddCSSMaxSize, and AddCSSFlex by replacing CSS with XUL. r=dholbert (4e79b90b1f) - Bug 1053986 - Fix ordering of methods in nsIFrame.h r=dholbert (fb08aa035f) - Bug 1053986 - Rename nsBox::BeginLayout to BeginXULLayout. r=dholbert (595cb70526) - Bug 1053986 - Rename nsBox::EndLayout to EndXULLayout. r=dholbert (13f98a84a0) - Bug 1213895: Part 1 - Correctly support crop="none" in XUL labels. r=neil (053e0c8414) - Bug 1053986 - Rename nsBox::DoLayout to DoXULLayout. r=dholbert (40ef0ece53) - Bug 1144619 - Variable 'nextX' is created in the wrong scope. r=dbaron (7893ccb301) - Bug 1172011 - Remove unneeded 'spaceLeft' declaration from nsSplitterFrame.cpp. r=froydnj (7ef937e283) - Bug 1192376: Make nsImageBoxFrame check whether image size is available before trying to paint an image. r=seth (2db203eb3b) - Bug 1240533 - Parameters to ScreenForRect need to be passed as desktop pixels, not device pixels. r=emk (d49b532344) - Bug 1212658 - Remove needless IsCallerChrome check in nsMenuPopupFrame. r=bz (bdf0d16a49) - Bug 374471 Make the noautohide attribute live where supported r=enndeakin (f696b4d174) - Bug 1200870, allow -1 as a value to popup.moveTo, r=tn (10e05d4240) - Bug 1182856 - Part 1: Add StopTransitionsForElement. r=heycam (1c0ac374c4) - Bug 1182856 - Part 2: Let AnimationsWithDestroyFrame destroy transitions. r=heycam (7820f7b1e5) - Bug 1182856 - Part 3: Cancel transitions for destroy frames. r=heycam (439fb07545) - Bug 1157936 - Put the correct ratio on the scrollbar layer. r=tn (a64f35b9ea) - Bug 1238137 - Telemetry pings for main thread scrollbar-driven scroll input methods. r=kats (89e5187b88) - Bug 1156106 - Make nsMenuBarFrame::mMenuBarListener an nsRefPtr; r=roc (838126cd16) - Bug 1163304 Close all existing popups when menubar becomes active because it should have pseudo focus and other popups shouldn't handle key events r=enn+neil (933c9ae40e) - Bug 1252693 - Assert that we do not tenure into an OMT Zone; r=sfink (0812fc81f2) - Bug 1265679 - Always call the object moved hook in generational GC r=terrence (6d75efba2d) - Bug 1265825 - Remove mSuppressionActive assert. r=kats (3b6b3ba030) - Bug 1250226 - Only report compacting GC telemetry for compacting GCs r=terrence (4e0f511ccf) - Bug 1258578: Improve documentation for js::RelocatablePtr. DONTBUILD r=terrence (3ed2a933e0) - Bug 1252713 - Fix FILES_PER_UNIFIED_FILE=1 bustage in js/. r=terrence (8a97e6c7e2) - Bug 1265741: Fix unified build for fuzzers; r=nbp (ad3b4a4543) - Bug 1013219 - set the line number of the terminating retrval; r=jimb, r=ejpbruel, r=fitzgen (df810884a9) - Bug 1013219 - set line number of return instruction; r=efaust, r=fitzgen, r=ejpbruel (503b1a2bf3) - Bug 1260577 - Fix |obj[expr] += e2| erroneously calling expr.toString() twice. (r=till) (e2485baccb) - Bug 1260577 - followup: Change confusing name SelfAssign to CompoundAssign. (rs=jorendorff) (51a7dee68e) - Bug 1263881 - Check the the number of body level lexicals doesn't exceed that which we can store in Bindings r=shu (d610d7a1e9) - Bug 1258097 - Check for redeclaration of imports by functions r=shu (78f06f273f) - Bug 1264954 - Add missing OOM check in Parser::templateLiteral. r=jonco (2743a82e1e) - Bug 1265313 - Fix Annex B.3.5 handling with body-level lexicals. (r=jorendorff) (6b4139d25b) - Bug 1260620 - Ensure that possibleErrors are not null before attempting to check them; r=jorendorff (6b284c1107) - Bug 1253275 - Remove const_casts from Runtime.cpp. r=sfink (40b6d68455) - Bug 1262731 - Add JS_InitWithFailureDiagnostic(). r=sfink. (310579fcd3) - Bug 1263886 - Don't call makeConstructorCode if the group has unknown properties. r=bhackett (e81c939928) - Bug 1260891 - Acquire and release the lock when destorying an `ExclusiveData<T>`'s protected value; r=terrence a=kwierso (dc39af575e) - Bug 1252034 - Value Numbering: Unconditionally generate fixup blocks. r=sunfish (3b46b2df51) - Bug 1232229 - Ensure generator object prototype is a singleton and tenured. r=jonco (d0c4f17cb6)
991 lines
25 KiB
C++
991 lines
25 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#include "nsBoxLayoutState.h"
|
|
#include "nsBox.h"
|
|
#include "nsBoxFrame.h"
|
|
#include "nsPresContext.h"
|
|
#include "nsCOMPtr.h"
|
|
#include "nsIContent.h"
|
|
#include "nsContainerFrame.h"
|
|
#include "nsNameSpaceManager.h"
|
|
#include "nsGkAtoms.h"
|
|
#include "nsIDOMNode.h"
|
|
#include "nsIDOMMozNamedAttrMap.h"
|
|
#include "nsIDOMAttr.h"
|
|
#include "nsITheme.h"
|
|
#include "nsIServiceManager.h"
|
|
#include "nsBoxLayout.h"
|
|
#include "FrameLayerBuilder.h"
|
|
#include <algorithm>
|
|
|
|
using namespace mozilla;
|
|
|
|
#ifdef DEBUG_LAYOUT
|
|
int32_t gIndent = 0;
|
|
#endif
|
|
|
|
#ifdef DEBUG_LAYOUT
|
|
void
|
|
nsBoxAddIndents()
|
|
{
|
|
for(int32_t i=0; i < gIndent; i++)
|
|
{
|
|
printf(" ");
|
|
}
|
|
}
|
|
#endif
|
|
|
|
#ifdef DEBUG_LAYOUT
|
|
void
|
|
nsBox::AppendAttribute(const nsAutoString& aAttribute, const nsAutoString& aValue, nsAutoString& aResult)
|
|
{
|
|
aResult.Append(aAttribute);
|
|
aResult.AppendLiteral("='");
|
|
aResult.Append(aValue);
|
|
aResult.AppendLiteral("' ");
|
|
}
|
|
|
|
void
|
|
nsBox::ListBox(nsAutoString& aResult)
|
|
{
|
|
nsAutoString name;
|
|
GetBoxName(name);
|
|
|
|
char addr[100];
|
|
sprintf(addr, "[@%p] ", static_cast<void*>(this));
|
|
|
|
aResult.AppendASCII(addr);
|
|
aResult.Append(name);
|
|
aResult.Append(' ');
|
|
|
|
nsIContent* content = GetContent();
|
|
|
|
// add on all the set attributes
|
|
if (content) {
|
|
nsCOMPtr<nsIDOMNode> node(do_QueryInterface(content));
|
|
nsCOMPtr<nsIDOMMozNamedAttrMap> namedMap;
|
|
|
|
node->GetAttributes(getter_AddRefs(namedMap));
|
|
uint32_t length;
|
|
namedMap->GetLength(&length);
|
|
|
|
nsCOMPtr<nsIDOMAttr> attribute;
|
|
for (uint32_t i = 0; i < length; ++i)
|
|
{
|
|
namedMap->Item(i, getter_AddRefs(attribute));
|
|
attribute->GetName(name);
|
|
nsAutoString value;
|
|
attribute->GetValue(value);
|
|
AppendAttribute(name, value, aResult);
|
|
}
|
|
}
|
|
}
|
|
|
|
nsresult
|
|
nsBox::XULDumpBox(FILE* aFile)
|
|
{
|
|
nsAutoString s;
|
|
ListBox(s);
|
|
fprintf(aFile, "%s", NS_LossyConvertUTF16toASCII(s).get());
|
|
return NS_OK;
|
|
}
|
|
|
|
void
|
|
nsBox::PropagateDebug(nsBoxLayoutState& aState)
|
|
{
|
|
// propagate debug information
|
|
if (mState & NS_STATE_DEBUG_WAS_SET) {
|
|
if (mState & NS_STATE_SET_TO_DEBUG)
|
|
SetXULDebug(aState, true);
|
|
else
|
|
SetXULDebug(aState, false);
|
|
} else if (mState & NS_STATE_IS_ROOT) {
|
|
SetXULDebug(aState, gDebug);
|
|
}
|
|
}
|
|
#endif
|
|
|
|
#ifdef DEBUG_LAYOUT
|
|
void
|
|
nsBox::GetBoxName(nsAutoString& aName)
|
|
{
|
|
aName.AssignLiteral("Box");
|
|
}
|
|
#endif
|
|
|
|
nsresult
|
|
nsBox::BeginXULLayout(nsBoxLayoutState& aState)
|
|
{
|
|
#ifdef DEBUG_LAYOUT
|
|
|
|
nsBoxAddIndents();
|
|
printf("XULLayout: ");
|
|
XULDumpBox(stdout);
|
|
printf("\n");
|
|
gIndent++;
|
|
#endif
|
|
|
|
// mark ourselves as dirty so no child under us
|
|
// can post an incremental layout.
|
|
// XXXldb Is this still needed?
|
|
mState |= NS_FRAME_HAS_DIRTY_CHILDREN;
|
|
|
|
if (GetStateBits() & NS_FRAME_IS_DIRTY)
|
|
{
|
|
// If the parent is dirty, all the children are dirty (nsHTMLReflowState
|
|
// does this too).
|
|
nsIFrame* box;
|
|
for (box = GetChildXULBox(this); box; box = GetNextXULBox(box))
|
|
box->AddStateBits(NS_FRAME_IS_DIRTY);
|
|
}
|
|
|
|
// Another copy-over from nsHTMLReflowState.
|
|
// Since we are in reflow, we don't need to store these properties anymore.
|
|
FrameProperties props = Properties();
|
|
props.Delete(UsedBorderProperty());
|
|
props.Delete(UsedPaddingProperty());
|
|
props.Delete(UsedMarginProperty());
|
|
|
|
#ifdef DEBUG_LAYOUT
|
|
PropagateDebug(aState);
|
|
#endif
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsBox::DoXULLayout(nsBoxLayoutState& aState)
|
|
{
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
nsBox::EndXULLayout(nsBoxLayoutState& aState)
|
|
{
|
|
|
|
#ifdef DEBUG_LAYOUT
|
|
--gIndent;
|
|
#endif
|
|
|
|
return SyncLayout(aState);
|
|
}
|
|
|
|
bool nsBox::gGotTheme = false;
|
|
nsITheme* nsBox::gTheme = nullptr;
|
|
|
|
nsBox::nsBox()
|
|
{
|
|
MOZ_COUNT_CTOR(nsBox);
|
|
//mX = 0;
|
|
//mY = 0;
|
|
if (!gGotTheme) {
|
|
gGotTheme = true;
|
|
CallGetService("@mozilla.org/chrome/chrome-native-theme;1", &gTheme);
|
|
}
|
|
}
|
|
|
|
nsBox::~nsBox()
|
|
{
|
|
// NOTE: This currently doesn't get called for |nsBoxToBlockAdaptor|
|
|
// objects, so don't rely on putting anything here.
|
|
MOZ_COUNT_DTOR(nsBox);
|
|
}
|
|
|
|
/* static */ void
|
|
nsBox::Shutdown()
|
|
{
|
|
gGotTheme = false;
|
|
NS_IF_RELEASE(gTheme);
|
|
}
|
|
|
|
nsresult
|
|
nsBox::XULRelayoutChildAtOrdinal(nsIFrame* aChild)
|
|
{
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
nsIFrame::GetXULClientRect(nsRect& aClientRect)
|
|
{
|
|
aClientRect = mRect;
|
|
aClientRect.MoveTo(0,0);
|
|
|
|
nsMargin borderPadding;
|
|
GetXULBorderAndPadding(borderPadding);
|
|
|
|
aClientRect.Deflate(borderPadding);
|
|
|
|
if (aClientRect.width < 0)
|
|
aClientRect.width = 0;
|
|
|
|
if (aClientRect.height < 0)
|
|
aClientRect.height = 0;
|
|
|
|
// NS_ASSERTION(aClientRect.width >=0 && aClientRect.height >= 0, "Content Size < 0");
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
void
|
|
nsBox::SetXULBounds(nsBoxLayoutState& aState, const nsRect& aRect, bool aRemoveOverflowAreas)
|
|
{
|
|
NS_BOX_ASSERTION(this, aRect.width >=0 && aRect.height >= 0, "SetXULBounds Size < 0");
|
|
|
|
nsRect rect(mRect);
|
|
|
|
uint32_t flags = 0;
|
|
GetLayoutFlags(flags);
|
|
|
|
uint32_t stateFlags = aState.LayoutFlags();
|
|
|
|
flags |= stateFlags;
|
|
|
|
if ((flags & NS_FRAME_NO_MOVE_FRAME) == NS_FRAME_NO_MOVE_FRAME)
|
|
SetSize(aRect.Size());
|
|
else
|
|
SetRect(aRect);
|
|
|
|
// Nuke the overflow area. The caller is responsible for restoring
|
|
// it if necessary.
|
|
if (aRemoveOverflowAreas) {
|
|
// remove the previously stored overflow area
|
|
ClearOverflowRects();
|
|
}
|
|
|
|
if (!(flags & NS_FRAME_NO_MOVE_VIEW))
|
|
{
|
|
nsContainerFrame::PositionFrameView(this);
|
|
if ((rect.x != aRect.x) || (rect.y != aRect.y))
|
|
nsContainerFrame::PositionChildViews(this);
|
|
}
|
|
|
|
|
|
/*
|
|
// only if the origin changed
|
|
if ((rect.x != aRect.x) || (rect.y != aRect.y)) {
|
|
if (frame->HasView()) {
|
|
nsContainerFrame::PositionFrameView(presContext, frame,
|
|
frame->GetView());
|
|
} else {
|
|
nsContainerFrame::PositionChildViews(presContext, frame);
|
|
}
|
|
}
|
|
*/
|
|
}
|
|
|
|
void
|
|
nsBox::GetLayoutFlags(uint32_t& aFlags)
|
|
{
|
|
aFlags = 0;
|
|
}
|
|
|
|
|
|
nsresult
|
|
nsIFrame::GetXULBorderAndPadding(nsMargin& aBorderAndPadding)
|
|
{
|
|
aBorderAndPadding.SizeTo(0, 0, 0, 0);
|
|
nsresult rv = GetXULBorder(aBorderAndPadding);
|
|
if (NS_FAILED(rv))
|
|
return rv;
|
|
|
|
nsMargin padding;
|
|
rv = GetXULPadding(padding);
|
|
if (NS_FAILED(rv))
|
|
return rv;
|
|
|
|
aBorderAndPadding += padding;
|
|
|
|
return rv;
|
|
}
|
|
|
|
nsresult
|
|
nsBox::GetXULBorder(nsMargin& aMargin)
|
|
{
|
|
aMargin.SizeTo(0,0,0,0);
|
|
|
|
const nsStyleDisplay* disp = StyleDisplay();
|
|
if (disp->mAppearance && gTheme) {
|
|
// Go to the theme for the border.
|
|
nsPresContext *context = PresContext();
|
|
if (gTheme->ThemeSupportsWidget(context, this, disp->mAppearance)) {
|
|
nsIntMargin margin(0, 0, 0, 0);
|
|
gTheme->GetWidgetBorder(context->DeviceContext(), this,
|
|
disp->mAppearance, &margin);
|
|
aMargin.top = context->DevPixelsToAppUnits(margin.top);
|
|
aMargin.right = context->DevPixelsToAppUnits(margin.right);
|
|
aMargin.bottom = context->DevPixelsToAppUnits(margin.bottom);
|
|
aMargin.left = context->DevPixelsToAppUnits(margin.left);
|
|
return NS_OK;
|
|
}
|
|
}
|
|
|
|
aMargin = StyleBorder()->GetComputedBorder();
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
nsBox::GetXULPadding(nsMargin& aMargin)
|
|
{
|
|
const nsStyleDisplay *disp = StyleDisplay();
|
|
if (disp->mAppearance && gTheme) {
|
|
// Go to the theme for the padding.
|
|
nsPresContext *context = PresContext();
|
|
if (gTheme->ThemeSupportsWidget(context, this, disp->mAppearance)) {
|
|
nsIntMargin margin(0, 0, 0, 0);
|
|
bool useThemePadding;
|
|
|
|
useThemePadding = gTheme->GetWidgetPadding(context->DeviceContext(),
|
|
this, disp->mAppearance,
|
|
&margin);
|
|
if (useThemePadding) {
|
|
aMargin.top = context->DevPixelsToAppUnits(margin.top);
|
|
aMargin.right = context->DevPixelsToAppUnits(margin.right);
|
|
aMargin.bottom = context->DevPixelsToAppUnits(margin.bottom);
|
|
aMargin.left = context->DevPixelsToAppUnits(margin.left);
|
|
return NS_OK;
|
|
}
|
|
}
|
|
}
|
|
|
|
aMargin.SizeTo(0,0,0,0);
|
|
StylePadding()->GetPadding(aMargin);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
nsBox::GetXULMargin(nsMargin& aMargin)
|
|
{
|
|
aMargin.SizeTo(0,0,0,0);
|
|
StyleMargin()->GetMargin(aMargin);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
void
|
|
nsBox::SizeNeedsRecalc(nsSize& aSize)
|
|
{
|
|
aSize.width = -1;
|
|
aSize.height = -1;
|
|
}
|
|
|
|
void
|
|
nsBox::CoordNeedsRecalc(nscoord& aFlex)
|
|
{
|
|
aFlex = -1;
|
|
}
|
|
|
|
bool
|
|
nsBox::DoesNeedRecalc(const nsSize& aSize)
|
|
{
|
|
return (aSize.width == -1 || aSize.height == -1);
|
|
}
|
|
|
|
bool
|
|
nsBox::DoesNeedRecalc(nscoord aCoord)
|
|
{
|
|
return (aCoord == -1);
|
|
}
|
|
|
|
nsSize
|
|
nsBox::GetXULPrefSize(nsBoxLayoutState& aState)
|
|
{
|
|
NS_ASSERTION(aState.GetRenderingContext(), "must have rendering context");
|
|
|
|
nsSize pref(0,0);
|
|
DISPLAY_PREF_SIZE(this, pref);
|
|
|
|
if (IsXULCollapsed())
|
|
return pref;
|
|
|
|
AddBorderAndPadding(pref);
|
|
bool widthSet, heightSet;
|
|
nsIFrame::AddXULPrefSize(this, pref, widthSet, heightSet);
|
|
|
|
nsSize minSize = GetXULMinSize(aState);
|
|
nsSize maxSize = GetXULMaxSize(aState);
|
|
return BoundsCheck(minSize, pref, maxSize);
|
|
}
|
|
|
|
nsSize
|
|
nsBox::GetXULMinSize(nsBoxLayoutState& aState)
|
|
{
|
|
NS_ASSERTION(aState.GetRenderingContext(), "must have rendering context");
|
|
|
|
nsSize min(0,0);
|
|
DISPLAY_MIN_SIZE(this, min);
|
|
|
|
if (IsXULCollapsed())
|
|
return min;
|
|
|
|
AddBorderAndPadding(min);
|
|
bool widthSet, heightSet;
|
|
nsIFrame::AddXULMinSize(aState, this, min, widthSet, heightSet);
|
|
return min;
|
|
}
|
|
|
|
nsSize
|
|
nsBox::GetXULMinSizeForScrollArea(nsBoxLayoutState& aBoxLayoutState)
|
|
{
|
|
return nsSize(0, 0);
|
|
}
|
|
|
|
nsSize
|
|
nsBox::GetXULMaxSize(nsBoxLayoutState& aState)
|
|
{
|
|
NS_ASSERTION(aState.GetRenderingContext(), "must have rendering context");
|
|
|
|
nsSize maxSize(NS_INTRINSICSIZE, NS_INTRINSICSIZE);
|
|
DISPLAY_MAX_SIZE(this, maxSize);
|
|
|
|
if (IsXULCollapsed())
|
|
return maxSize;
|
|
|
|
AddBorderAndPadding(maxSize);
|
|
bool widthSet, heightSet;
|
|
nsIFrame::AddXULMaxSize(this, maxSize, widthSet, heightSet);
|
|
return maxSize;
|
|
}
|
|
|
|
nscoord
|
|
nsBox::GetXULFlex()
|
|
{
|
|
nscoord flex = 0;
|
|
|
|
nsIFrame::AddXULFlex(this, flex);
|
|
|
|
return flex;
|
|
}
|
|
|
|
uint32_t
|
|
nsIFrame::GetXULOrdinal()
|
|
{
|
|
uint32_t ordinal = StyleXUL()->mBoxOrdinal;
|
|
|
|
// When present, attribute value overrides CSS.
|
|
nsIContent* content = GetContent();
|
|
if (content && content->IsXULElement()) {
|
|
nsresult error;
|
|
nsAutoString value;
|
|
|
|
content->GetAttr(kNameSpaceID_None, nsGkAtoms::ordinal, value);
|
|
if (!value.IsEmpty()) {
|
|
ordinal = value.ToInteger(&error);
|
|
}
|
|
}
|
|
|
|
return ordinal;
|
|
}
|
|
|
|
nscoord
|
|
nsBox::GetXULBoxAscent(nsBoxLayoutState& aState)
|
|
{
|
|
if (IsXULCollapsed())
|
|
return 0;
|
|
|
|
return GetXULPrefSize(aState).height;
|
|
}
|
|
|
|
bool
|
|
nsBox::IsXULCollapsed()
|
|
{
|
|
return StyleVisibility()->mVisible == NS_STYLE_VISIBILITY_COLLAPSE;
|
|
}
|
|
|
|
nsresult
|
|
nsIFrame::XULLayout(nsBoxLayoutState& aState)
|
|
{
|
|
NS_ASSERTION(aState.GetRenderingContext(), "must have rendering context");
|
|
|
|
nsBox *box = static_cast<nsBox*>(this);
|
|
DISPLAY_LAYOUT(box);
|
|
|
|
box->BeginXULLayout(aState);
|
|
|
|
box->DoXULLayout(aState);
|
|
|
|
box->EndXULLayout(aState);
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
bool
|
|
nsBox::DoesClipChildren()
|
|
{
|
|
const nsStyleDisplay* display = StyleDisplay();
|
|
NS_ASSERTION((display->mOverflowY == NS_STYLE_OVERFLOW_CLIP) ==
|
|
(display->mOverflowX == NS_STYLE_OVERFLOW_CLIP),
|
|
"If one overflow is clip, the other should be too");
|
|
return display->mOverflowX == NS_STYLE_OVERFLOW_CLIP;
|
|
}
|
|
|
|
nsresult
|
|
nsBox::SyncLayout(nsBoxLayoutState& aState)
|
|
{
|
|
/*
|
|
if (IsXULCollapsed()) {
|
|
CollapseChild(aState, this, true);
|
|
return NS_OK;
|
|
}
|
|
*/
|
|
|
|
|
|
if (GetStateBits() & NS_FRAME_IS_DIRTY)
|
|
XULRedraw(aState);
|
|
|
|
RemoveStateBits(NS_FRAME_HAS_DIRTY_CHILDREN | NS_FRAME_IS_DIRTY
|
|
| NS_FRAME_FIRST_REFLOW | NS_FRAME_IN_REFLOW);
|
|
|
|
nsPresContext* presContext = aState.PresContext();
|
|
|
|
uint32_t flags = 0;
|
|
GetLayoutFlags(flags);
|
|
|
|
uint32_t stateFlags = aState.LayoutFlags();
|
|
|
|
flags |= stateFlags;
|
|
|
|
nsRect visualOverflow;
|
|
|
|
if (ComputesOwnOverflowArea()) {
|
|
visualOverflow = GetVisualOverflowRect();
|
|
}
|
|
else {
|
|
nsRect rect(nsPoint(0, 0), GetSize());
|
|
nsOverflowAreas overflowAreas(rect, rect);
|
|
if (!DoesClipChildren() && !IsXULCollapsed()) {
|
|
// See if our child frames caused us to overflow after being laid
|
|
// out. If so, store the overflow area. This normally can't happen
|
|
// in XUL, but it can happen with the CSS 'outline' property and
|
|
// possibly with other exotic stuff (e.g. relatively positioned
|
|
// frames in HTML inside XUL).
|
|
nsLayoutUtils::UnionChildOverflow(this, overflowAreas);
|
|
}
|
|
|
|
FinishAndStoreOverflow(overflowAreas, GetSize());
|
|
visualOverflow = overflowAreas.VisualOverflow();
|
|
}
|
|
|
|
nsView* view = GetView();
|
|
if (view) {
|
|
// Make sure the frame's view is properly sized and positioned and has
|
|
// things like opacity correct
|
|
nsContainerFrame::SyncFrameViewAfterReflow(presContext, this, view,
|
|
visualOverflow, flags);
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
nsIFrame::XULRedraw(nsBoxLayoutState& aState)
|
|
{
|
|
if (aState.PaintingDisabled())
|
|
return NS_OK;
|
|
|
|
// nsStackLayout, at least, expects us to repaint descendants even
|
|
// if a damage rect is provided
|
|
InvalidateFrameSubtree();
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
bool
|
|
nsIFrame::AddXULPrefSize(nsIFrame* aBox, nsSize& aSize, bool &aWidthSet, bool &aHeightSet)
|
|
{
|
|
aWidthSet = false;
|
|
aHeightSet = false;
|
|
|
|
// add in the css min, max, pref
|
|
const nsStylePosition* position = aBox->StylePosition();
|
|
|
|
// see if the width or height was specifically set
|
|
// XXX Handle eStyleUnit_Enumerated?
|
|
// (Handling the eStyleUnit_Enumerated types requires
|
|
// GetXULPrefSize/GetXULMinSize methods that don't consider
|
|
// (min-/max-/)(width/height) properties.)
|
|
const nsStyleCoord &width = position->mWidth;
|
|
if (width.GetUnit() == eStyleUnit_Coord) {
|
|
aSize.width = width.GetCoordValue();
|
|
aWidthSet = true;
|
|
} else if (width.IsCalcUnit()) {
|
|
if (!width.CalcHasPercent()) {
|
|
// pass 0 for percentage basis since we know there are no %s
|
|
aSize.width = nsRuleNode::ComputeComputedCalc(width, 0);
|
|
if (aSize.width < 0)
|
|
aSize.width = 0;
|
|
aWidthSet = true;
|
|
}
|
|
}
|
|
|
|
const nsStyleCoord &height = position->mHeight;
|
|
if (height.GetUnit() == eStyleUnit_Coord) {
|
|
aSize.height = height.GetCoordValue();
|
|
aHeightSet = true;
|
|
} else if (height.IsCalcUnit()) {
|
|
if (!height.CalcHasPercent()) {
|
|
// pass 0 for percentage basis since we know there are no %s
|
|
aSize.height = nsRuleNode::ComputeComputedCalc(height, 0);
|
|
if (aSize.height < 0)
|
|
aSize.height = 0;
|
|
aHeightSet = true;
|
|
}
|
|
}
|
|
|
|
nsIContent* content = aBox->GetContent();
|
|
// ignore 'height' and 'width' attributes if the actual element is not XUL
|
|
// For example, we might be magic XUL frames whose primary content is an HTML
|
|
// <select>
|
|
if (content && content->IsXULElement()) {
|
|
nsAutoString value;
|
|
nsresult error;
|
|
|
|
content->GetAttr(kNameSpaceID_None, nsGkAtoms::width, value);
|
|
if (!value.IsEmpty()) {
|
|
value.Trim("%");
|
|
|
|
aSize.width =
|
|
nsPresContext::CSSPixelsToAppUnits(value.ToInteger(&error));
|
|
aWidthSet = true;
|
|
}
|
|
|
|
content->GetAttr(kNameSpaceID_None, nsGkAtoms::height, value);
|
|
if (!value.IsEmpty()) {
|
|
value.Trim("%");
|
|
|
|
aSize.height =
|
|
nsPresContext::CSSPixelsToAppUnits(value.ToInteger(&error));
|
|
aHeightSet = true;
|
|
}
|
|
}
|
|
|
|
return (aWidthSet && aHeightSet);
|
|
}
|
|
|
|
|
|
bool
|
|
nsIFrame::AddXULMinSize(nsBoxLayoutState& aState, nsIFrame* aBox, nsSize& aSize,
|
|
bool &aWidthSet, bool &aHeightSet)
|
|
{
|
|
aWidthSet = false;
|
|
aHeightSet = false;
|
|
|
|
bool canOverride = true;
|
|
|
|
// See if a native theme wants to supply a minimum size.
|
|
const nsStyleDisplay* display = aBox->StyleDisplay();
|
|
if (display->mAppearance) {
|
|
nsITheme *theme = aState.PresContext()->GetTheme();
|
|
if (theme && theme->ThemeSupportsWidget(aState.PresContext(), aBox, display->mAppearance)) {
|
|
LayoutDeviceIntSize size;
|
|
theme->GetMinimumWidgetSize(aState.PresContext(), aBox,
|
|
display->mAppearance, &size, &canOverride);
|
|
if (size.width) {
|
|
aSize.width = aState.PresContext()->DevPixelsToAppUnits(size.width);
|
|
aWidthSet = true;
|
|
}
|
|
if (size.height) {
|
|
aSize.height = aState.PresContext()->DevPixelsToAppUnits(size.height);
|
|
aHeightSet = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
// add in the css min, max, pref
|
|
const nsStylePosition* position = aBox->StylePosition();
|
|
|
|
// same for min size. Unfortunately min size is always set to 0. So for now
|
|
// we will assume 0 (as a coord) means not set.
|
|
const nsStyleCoord &minWidth = position->mMinWidth;
|
|
if ((minWidth.GetUnit() == eStyleUnit_Coord &&
|
|
minWidth.GetCoordValue() != 0) ||
|
|
(minWidth.IsCalcUnit() && !minWidth.CalcHasPercent())) {
|
|
nscoord min = nsRuleNode::ComputeCoordPercentCalc(minWidth, 0);
|
|
if (!aWidthSet || (min > aSize.width && canOverride)) {
|
|
aSize.width = min;
|
|
aWidthSet = true;
|
|
}
|
|
} else if (minWidth.GetUnit() == eStyleUnit_Percent) {
|
|
NS_ASSERTION(minWidth.GetPercentValue() == 0.0f,
|
|
"Non-zero percentage values not currently supported");
|
|
aSize.width = 0;
|
|
aWidthSet = true; // FIXME: should we really do this for
|
|
// nonzero values?
|
|
}
|
|
// XXX Handle eStyleUnit_Enumerated?
|
|
// (Handling the eStyleUnit_Enumerated types requires
|
|
// GetXULPrefSize/GetXULMinSize methods that don't consider
|
|
// (min-/max-/)(width/height) properties.
|
|
// calc() with percentage is treated like '0' (unset)
|
|
|
|
const nsStyleCoord &minHeight = position->mMinHeight;
|
|
if ((minHeight.GetUnit() == eStyleUnit_Coord &&
|
|
minHeight.GetCoordValue() != 0) ||
|
|
(minHeight.IsCalcUnit() && !minHeight.CalcHasPercent())) {
|
|
nscoord min = nsRuleNode::ComputeCoordPercentCalc(minHeight, 0);
|
|
if (!aHeightSet || (min > aSize.height && canOverride)) {
|
|
aSize.height = min;
|
|
aHeightSet = true;
|
|
}
|
|
} else if (minHeight.GetUnit() == eStyleUnit_Percent) {
|
|
NS_ASSERTION(position->mMinHeight.GetPercentValue() == 0.0f,
|
|
"Non-zero percentage values not currently supported");
|
|
aSize.height = 0;
|
|
aHeightSet = true; // FIXME: should we really do this for
|
|
// nonzero values?
|
|
}
|
|
// calc() with percentage is treated like '0' (unset)
|
|
|
|
nsIContent* content = aBox->GetContent();
|
|
if (content && content->IsXULElement()) {
|
|
nsAutoString value;
|
|
nsresult error;
|
|
|
|
content->GetAttr(kNameSpaceID_None, nsGkAtoms::minwidth, value);
|
|
if (!value.IsEmpty())
|
|
{
|
|
value.Trim("%");
|
|
|
|
nscoord val =
|
|
nsPresContext::CSSPixelsToAppUnits(value.ToInteger(&error));
|
|
if (val > aSize.width)
|
|
aSize.width = val;
|
|
aWidthSet = true;
|
|
}
|
|
|
|
content->GetAttr(kNameSpaceID_None, nsGkAtoms::minheight, value);
|
|
if (!value.IsEmpty())
|
|
{
|
|
value.Trim("%");
|
|
|
|
nscoord val =
|
|
nsPresContext::CSSPixelsToAppUnits(value.ToInteger(&error));
|
|
if (val > aSize.height)
|
|
aSize.height = val;
|
|
|
|
aHeightSet = true;
|
|
}
|
|
}
|
|
|
|
return (aWidthSet && aHeightSet);
|
|
}
|
|
|
|
bool
|
|
nsIFrame::AddXULMaxSize(nsIFrame* aBox, nsSize& aSize, bool &aWidthSet, bool &aHeightSet)
|
|
{
|
|
aWidthSet = false;
|
|
aHeightSet = false;
|
|
|
|
// add in the css min, max, pref
|
|
const nsStylePosition* position = aBox->StylePosition();
|
|
|
|
// and max
|
|
// see if the width or height was specifically set
|
|
// XXX Handle eStyleUnit_Enumerated?
|
|
// (Handling the eStyleUnit_Enumerated types requires
|
|
// GetXULPrefSize/GetXULMinSize methods that don't consider
|
|
// (min-/max-/)(width/height) properties.)
|
|
const nsStyleCoord maxWidth = position->mMaxWidth;
|
|
if (maxWidth.ConvertsToLength()) {
|
|
aSize.width = nsRuleNode::ComputeCoordPercentCalc(maxWidth, 0);
|
|
aWidthSet = true;
|
|
}
|
|
// percentages and calc() with percentages are treated like 'none'
|
|
|
|
const nsStyleCoord &maxHeight = position->mMaxHeight;
|
|
if (maxHeight.ConvertsToLength()) {
|
|
aSize.height = nsRuleNode::ComputeCoordPercentCalc(maxHeight, 0);
|
|
aHeightSet = true;
|
|
}
|
|
// percentages and calc() with percentages are treated like 'none'
|
|
|
|
nsIContent* content = aBox->GetContent();
|
|
if (content && content->IsXULElement()) {
|
|
nsAutoString value;
|
|
nsresult error;
|
|
|
|
content->GetAttr(kNameSpaceID_None, nsGkAtoms::maxwidth, value);
|
|
if (!value.IsEmpty()) {
|
|
value.Trim("%");
|
|
|
|
nscoord val =
|
|
nsPresContext::CSSPixelsToAppUnits(value.ToInteger(&error));
|
|
aSize.width = val;
|
|
aWidthSet = true;
|
|
}
|
|
|
|
content->GetAttr(kNameSpaceID_None, nsGkAtoms::maxheight, value);
|
|
if (!value.IsEmpty()) {
|
|
value.Trim("%");
|
|
|
|
nscoord val =
|
|
nsPresContext::CSSPixelsToAppUnits(value.ToInteger(&error));
|
|
aSize.height = val;
|
|
|
|
aHeightSet = true;
|
|
}
|
|
}
|
|
|
|
return (aWidthSet || aHeightSet);
|
|
}
|
|
|
|
bool
|
|
nsIFrame::AddXULFlex(nsIFrame* aBox, nscoord& aFlex)
|
|
{
|
|
bool flexSet = false;
|
|
|
|
// get the flexibility
|
|
aFlex = aBox->StyleXUL()->mBoxFlex;
|
|
|
|
// attribute value overrides CSS
|
|
nsIContent* content = aBox->GetContent();
|
|
if (content && content->IsXULElement()) {
|
|
nsresult error;
|
|
nsAutoString value;
|
|
|
|
content->GetAttr(kNameSpaceID_None, nsGkAtoms::flex, value);
|
|
if (!value.IsEmpty()) {
|
|
value.Trim("%");
|
|
aFlex = value.ToInteger(&error);
|
|
flexSet = true;
|
|
}
|
|
}
|
|
|
|
if (aFlex < 0)
|
|
aFlex = 0;
|
|
if (aFlex >= nscoord_MAX)
|
|
aFlex = nscoord_MAX - 1;
|
|
|
|
return flexSet || aFlex > 0;
|
|
}
|
|
|
|
void
|
|
nsBox::AddBorderAndPadding(nsSize& aSize)
|
|
{
|
|
AddBorderAndPadding(this, aSize);
|
|
}
|
|
|
|
void
|
|
nsBox::AddBorderAndPadding(nsIFrame* aBox, nsSize& aSize)
|
|
{
|
|
nsMargin borderPadding(0,0,0,0);
|
|
aBox->GetXULBorderAndPadding(borderPadding);
|
|
AddMargin(aSize, borderPadding);
|
|
}
|
|
|
|
void
|
|
nsBox::AddMargin(nsIFrame* aChild, nsSize& aSize)
|
|
{
|
|
nsMargin margin(0,0,0,0);
|
|
aChild->GetXULMargin(margin);
|
|
AddMargin(aSize, margin);
|
|
}
|
|
|
|
void
|
|
nsBox::AddMargin(nsSize& aSize, const nsMargin& aMargin)
|
|
{
|
|
if (aSize.width != NS_INTRINSICSIZE)
|
|
aSize.width += aMargin.left + aMargin.right;
|
|
|
|
if (aSize.height != NS_INTRINSICSIZE)
|
|
aSize.height += aMargin.top + aMargin.bottom;
|
|
}
|
|
|
|
nscoord
|
|
nsBox::BoundsCheck(nscoord aMin, nscoord aPref, nscoord aMax)
|
|
{
|
|
if (aPref > aMax)
|
|
aPref = aMax;
|
|
|
|
if (aPref < aMin)
|
|
aPref = aMin;
|
|
|
|
return aPref;
|
|
}
|
|
|
|
nsSize
|
|
nsBox::BoundsCheckMinMax(const nsSize& aMinSize, const nsSize& aMaxSize)
|
|
{
|
|
return nsSize(std::max(aMaxSize.width, aMinSize.width),
|
|
std::max(aMaxSize.height, aMinSize.height));
|
|
}
|
|
|
|
nsSize
|
|
nsBox::BoundsCheck(const nsSize& aMinSize, const nsSize& aPrefSize, const nsSize& aMaxSize)
|
|
{
|
|
return nsSize(BoundsCheck(aMinSize.width, aPrefSize.width, aMaxSize.width),
|
|
BoundsCheck(aMinSize.height, aPrefSize.height, aMaxSize.height));
|
|
}
|
|
|
|
/*static*/ nsIFrame*
|
|
nsBox::GetChildXULBox(const nsIFrame* aFrame)
|
|
{
|
|
// box layout ends at box-wrapped frames, so don't allow these frames
|
|
// to report child boxes.
|
|
return aFrame->IsXULBoxFrame() ? aFrame->PrincipalChildList().FirstChild() : nullptr;
|
|
}
|
|
|
|
/*static*/ nsIFrame*
|
|
nsBox::GetNextXULBox(const nsIFrame* aFrame)
|
|
{
|
|
return aFrame->GetParent() &&
|
|
aFrame->GetParent()->IsXULBoxFrame() ? aFrame->GetNextSibling() : nullptr;
|
|
}
|
|
|
|
/*static*/ nsIFrame*
|
|
nsBox::GetParentXULBox(const nsIFrame* aFrame)
|
|
{
|
|
return aFrame->GetParent() &&
|
|
aFrame->GetParent()->IsXULBoxFrame() ? aFrame->GetParent() : nullptr;
|
|
}
|
|
|
|
#ifdef DEBUG_LAYOUT
|
|
nsresult
|
|
nsBox::SetXULDebug(nsBoxLayoutState& aState, bool aDebug)
|
|
{
|
|
return NS_OK;
|
|
}
|
|
|
|
NS_IMETHODIMP
|
|
nsBox::GetDebugBoxAt( const nsPoint& aPoint,
|
|
nsIFrame** aBox)
|
|
{
|
|
nsRect thisRect(nsPoint(0,0), GetSize());
|
|
if (!thisRect.Contains(aPoint))
|
|
return NS_ERROR_FAILURE;
|
|
|
|
nsIFrame* child = nsBox::GetChildXULBox(this);
|
|
nsIFrame* hit = nullptr;
|
|
|
|
*aBox = nullptr;
|
|
while (nullptr != child) {
|
|
nsresult rv = child->GetDebugBoxAt(aPoint - child->GetOffsetTo(this), &hit);
|
|
|
|
if (NS_SUCCEEDED(rv) && hit) {
|
|
*aBox = hit;
|
|
}
|
|
child = GetNextXULBox(child);
|
|
}
|
|
|
|
// found a child
|
|
if (*aBox) {
|
|
return NS_OK;
|
|
}
|
|
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
|
|
nsresult
|
|
nsBox::GetXULDebug(bool& aDebug)
|
|
{
|
|
aDebug = false;
|
|
return NS_OK;
|
|
}
|
|
|
|
#endif
|