зеркало из https://github.com/mozilla/pjs.git
Bug 458231 Frame overflow plays havoc with size of <label> or <description> r+sr=roc r=dao for backout of workaround for bug 69710
This commit is contained in:
Родитель
9c3d288b64
Коммит
49b184e984
|
@ -6560,6 +6560,13 @@ nsFrame::BoxReflow(nsBoxLayoutState& aState,
|
||||||
computedWidth = PR_MAX(computedWidth, 0);
|
computedWidth = PR_MAX(computedWidth, 0);
|
||||||
reflowState.SetComputedWidth(computedWidth);
|
reflowState.SetComputedWidth(computedWidth);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Most child frames of box frames (e.g. subdocument or scroll frames)
|
||||||
|
// need to be constrained to the provided size and overflow as necessary.
|
||||||
|
// The one exception are block frames, because we need to know their
|
||||||
|
// natural height excluding any overflow area which may be caused by
|
||||||
|
// various CSS effects such as shadow or outline.
|
||||||
|
if (!IsFrameOfType(eBlockFrame)) {
|
||||||
if (aHeight != NS_INTRINSICSIZE) {
|
if (aHeight != NS_INTRINSICSIZE) {
|
||||||
nscoord computedHeight =
|
nscoord computedHeight =
|
||||||
aHeight - reflowState.mComputedBorderPadding.TopBottom();
|
aHeight - reflowState.mComputedBorderPadding.TopBottom();
|
||||||
|
@ -6579,6 +6586,7 @@ nsFrame::BoxReflow(nsBoxLayoutState& aState,
|
||||||
PR_FALSE).height
|
PR_FALSE).height
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Box layout calls SetRect before Layout, whereas non-box layout
|
// Box layout calls SetRect before Layout, whereas non-box layout
|
||||||
// calls SetRect after Reflow.
|
// calls SetRect after Reflow.
|
||||||
|
@ -6607,52 +6615,6 @@ nsFrame::BoxReflow(nsBoxLayoutState& aState,
|
||||||
|
|
||||||
NS_ASSERTION(NS_FRAME_IS_COMPLETE(status), "bad status");
|
NS_ASSERTION(NS_FRAME_IS_COMPLETE(status), "bad status");
|
||||||
|
|
||||||
// printf("width: %d, height: %d\n", aDesiredSize.mCombinedArea.width, aDesiredSize.mCombinedArea.height);
|
|
||||||
|
|
||||||
// see if the overflow option is set. If it is then if our child's bounds overflow then
|
|
||||||
// we will set the child's rect to include the overflow size.
|
|
||||||
if (GetStateBits() & NS_FRAME_OUTSIDE_CHILDREN) {
|
|
||||||
// This kinda sucks. We should be able to handle the case
|
|
||||||
// where there's overflow above or to the left of the
|
|
||||||
// origin. But for now just chop that stuff off.
|
|
||||||
// (note: For RTL mode, replace "to the left of the origin"
|
|
||||||
// with "to the right of the range [0, aDesiredSize.width]")
|
|
||||||
|
|
||||||
//printf("OutsideChildren width=%d, height=%d\n", aDesiredSize.mOverflowArea.width, aDesiredSize.mOverflowArea.height);
|
|
||||||
|
|
||||||
if (NS_STYLE_DIRECTION_LTR == GetStyleVisibility()->mDirection) {
|
|
||||||
// LTR mode -- extend for overflow on right side.
|
|
||||||
aDesiredSize.width = PR_MAX(aDesiredSize.width,
|
|
||||||
aDesiredSize.mOverflowArea.XMost());
|
|
||||||
} else {
|
|
||||||
// RTL mode -- extend for overflow on left side.
|
|
||||||
nscoord leftmostValue = PR_MIN(0, aDesiredSize.mOverflowArea.x);
|
|
||||||
// Note: If anything, this increases aDesiredSize.width, because
|
|
||||||
// leftmostValue is non-positive.
|
|
||||||
aDesiredSize.width = aDesiredSize.width - leftmostValue;
|
|
||||||
}
|
|
||||||
if (aDesiredSize.width <= aWidth) {
|
|
||||||
aDesiredSize.height = aDesiredSize.mOverflowArea.YMost();
|
|
||||||
} else {
|
|
||||||
nscoord computedWidth = aDesiredSize.width -
|
|
||||||
reflowState.mComputedBorderPadding.LeftRight();
|
|
||||||
computedWidth = PR_MAX(computedWidth, 0);
|
|
||||||
reflowState.SetComputedWidth(computedWidth);
|
|
||||||
reflowState.availableWidth = aDesiredSize.width;
|
|
||||||
DidReflow(aPresContext, &reflowState, NS_FRAME_REFLOW_FINISHED);
|
|
||||||
#ifdef DEBUG_REFLOW
|
|
||||||
nsAdaptorAddIndents();
|
|
||||||
nsAdaptorPrintReason(reflowState);
|
|
||||||
printf("\n");
|
|
||||||
#endif
|
|
||||||
AddStateBits(NS_FRAME_IS_DIRTY);
|
|
||||||
WillReflow(aPresContext);
|
|
||||||
Reflow(aPresContext, aDesiredSize, reflowState, status);
|
|
||||||
if (GetStateBits() & NS_FRAME_OUTSIDE_CHILDREN)
|
|
||||||
aDesiredSize.height = aDesiredSize.mOverflowArea.YMost();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (redrawAfterReflow) {
|
if (redrawAfterReflow) {
|
||||||
nsRect r = GetRect();
|
nsRect r = GetRect();
|
||||||
r.width = aDesiredSize.width;
|
r.width = aDesiredSize.width;
|
||||||
|
|
|
@ -83,15 +83,6 @@ checkbox[disabled="true"] {
|
||||||
color: GrayText;
|
color: GrayText;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* XXX Hack to work around bug 458231 */
|
|
||||||
checkbox:-moz-system-metric(windows-classic) {
|
|
||||||
text-shadow: 1px 1px transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
checkbox:-moz-system-metric(windows-classic) > .checkbox-label-box > .checkbox-label {
|
|
||||||
margin-bottom: -2px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
checkbox[disabled="true"]:-moz-system-metric(windows-classic) {
|
checkbox[disabled="true"]:-moz-system-metric(windows-classic) {
|
||||||
color: ThreeDShadow;
|
color: ThreeDShadow;
|
||||||
text-shadow: 1px 1px ThreeDHighlight;
|
text-shadow: 1px 1px ThreeDHighlight;
|
||||||
|
|
|
@ -86,15 +86,6 @@ radio[disabled="true"] {
|
||||||
color: GrayText;
|
color: GrayText;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* XXX Hack to work around bug 458231 */
|
|
||||||
radio:-moz-system-metric(windows-classic) {
|
|
||||||
text-shadow: 1px 1px transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
radio:-moz-system-metric(windows-classic) > .radio-label-box > .radio-label {
|
|
||||||
margin-bottom: -2px !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
radio[disabled="true"]:-moz-system-metric(windows-classic) {
|
radio[disabled="true"]:-moz-system-metric(windows-classic) {
|
||||||
color: ThreeDShadow;
|
color: ThreeDShadow;
|
||||||
text-shadow: 1px 1px ThreeDHighlight;
|
text-shadow: 1px 1px ThreeDHighlight;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче