mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-12-13 18:27:35 +00:00
bug 11026 - rounding error on balancing when max element size is too large.
This commit is contained in:
parent
a099869098
commit
580f6c95ec
@ -1077,9 +1077,9 @@ AC_Wrapup(nsTableFrame* aTableFrame,
|
|||||||
|
|
||||||
void
|
void
|
||||||
AC_Increase(PRInt32 aNumAutoCols,
|
AC_Increase(PRInt32 aNumAutoCols,
|
||||||
nsColInfo** aColInfo,
|
nsColInfo** aColInfo,
|
||||||
PRInt32 aDivisor,
|
PRInt32 aDivisor,
|
||||||
PRInt32& aAvailWidth)
|
PRInt32& aAvailWidth)
|
||||||
{
|
{
|
||||||
for (PRInt32 i = 0; i < aNumAutoCols; i++) {
|
for (PRInt32 i = 0; i < aNumAutoCols; i++) {
|
||||||
if ((aAvailWidth <= 0) || (aDivisor <= 0)) {
|
if ((aAvailWidth <= 0) || (aDivisor <= 0)) {
|
||||||
@ -1087,12 +1087,15 @@ AC_Increase(PRInt32 aNumAutoCols,
|
|||||||
}
|
}
|
||||||
float percent = ((float)aColInfo[i]->mMaxWidth) / (float)aDivisor;
|
float percent = ((float)aColInfo[i]->mMaxWidth) / (float)aDivisor;
|
||||||
aDivisor -= aColInfo[i]->mMaxWidth;
|
aDivisor -= aColInfo[i]->mMaxWidth;
|
||||||
nscoord addition = PR_MIN(aAvailWidth, NSToCoordRound(((float)(aAvailWidth)) * percent));
|
nscoord addition = NSToCoordRound(((float)(aAvailWidth)) * percent);
|
||||||
addition = PR_MIN(addition, aColInfo[i]->mMaxWidth - aColInfo[i]->mWidth);
|
// if its the last col, try to give what's left to it
|
||||||
// don't let the total additions exceed what is available
|
if ((i == aNumAutoCols - 1) && (addition < aAvailWidth)) {
|
||||||
if (i == aNumAutoCols - 1) {
|
addition = aAvailWidth;
|
||||||
addition = PR_MIN(addition, aAvailWidth);
|
|
||||||
}
|
}
|
||||||
|
// don't let the addition exceed what is available to add
|
||||||
|
addition = PR_MIN(addition, aAvailWidth);
|
||||||
|
// don't go over the col max
|
||||||
|
addition = PR_MIN(addition, aColInfo[i]->mMaxWidth - aColInfo[i]->mWidth);
|
||||||
aColInfo[i]->mWidth += addition;
|
aColInfo[i]->mWidth += addition;
|
||||||
aAvailWidth -= addition;
|
aAvailWidth -= addition;
|
||||||
}
|
}
|
||||||
@ -1100,9 +1103,9 @@ AC_Increase(PRInt32 aNumAutoCols,
|
|||||||
|
|
||||||
void
|
void
|
||||||
AC_Decrease(PRInt32 aNumAutoCols,
|
AC_Decrease(PRInt32 aNumAutoCols,
|
||||||
nsColInfo** aColInfo,
|
nsColInfo** aColInfo,
|
||||||
PRInt32 aDivisor,
|
PRInt32 aDivisor,
|
||||||
PRInt32& aExcess)
|
PRInt32& aExcess)
|
||||||
{
|
{
|
||||||
for (PRInt32 i = 0; i < aNumAutoCols; i++) {
|
for (PRInt32 i = 0; i < aNumAutoCols; i++) {
|
||||||
if ((aExcess <= 0) || (aDivisor <= 0)) {
|
if ((aExcess <= 0) || (aDivisor <= 0)) {
|
||||||
@ -1110,19 +1113,20 @@ AC_Decrease(PRInt32 aNumAutoCols,
|
|||||||
}
|
}
|
||||||
float percent = ((float)aColInfo[i]->mMaxWidth) / (float)aDivisor;
|
float percent = ((float)aColInfo[i]->mMaxWidth) / (float)aDivisor;
|
||||||
aDivisor -= aColInfo[i]->mMaxWidth;
|
aDivisor -= aColInfo[i]->mMaxWidth;
|
||||||
nscoord reduction = PR_MIN(aExcess, NSToCoordRound(((float)(aExcess)) * percent));
|
nscoord reduction = NSToCoordRound(((float)(aExcess)) * percent);
|
||||||
// don't go over the col min
|
// if its the last col, try to remove the remaining excess from it
|
||||||
reduction = PR_MIN(reduction, aColInfo[i]->mWidth - aColInfo[i]->mMinWidth);
|
if ((i == aNumAutoCols - 1) && (reduction < aExcess)) {
|
||||||
// don't let the total reductions exceed what is available
|
reduction = aExcess;
|
||||||
if (i == aNumAutoCols - 1) {
|
|
||||||
reduction = PR_MIN(reduction, aExcess);
|
|
||||||
}
|
}
|
||||||
|
// don't let the reduction exceed what is available to reduce
|
||||||
|
reduction = PR_MIN(reduction, aExcess);
|
||||||
|
// don't go under the col min
|
||||||
|
reduction = PR_MIN(reduction, aColInfo[i]->mWidth - aColInfo[i]->mMinWidth);
|
||||||
aColInfo[i]->mWidth -= reduction;
|
aColInfo[i]->mWidth -= reduction;
|
||||||
aExcess -= reduction;
|
aExcess -= reduction;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
AC_Sort(nsColInfo** aColInfo, PRInt32 aNumCols)
|
AC_Sort(nsColInfo** aColInfo, PRInt32 aNumCols)
|
||||||
{
|
{
|
||||||
|
@ -52,7 +52,6 @@ static PRBool DEBUG_REFLOW_ROWGRP = PR_FALSE;
|
|||||||
static PRBool DEBUG_REFLOW_ROW = PR_FALSE;
|
static PRBool DEBUG_REFLOW_ROW = PR_FALSE;
|
||||||
static PRBool DEBUG_REFLOW_CELL = PR_FALSE;
|
static PRBool DEBUG_REFLOW_CELL = PR_FALSE;
|
||||||
static PRBool DEBUG_REFLOW_AREA = PR_FALSE;
|
static PRBool DEBUG_REFLOW_AREA = PR_FALSE;
|
||||||
|
|
||||||
/* ============================================================================ */
|
/* ============================================================================ */
|
||||||
|
|
||||||
/** nsTableFrame maps the inner portion of a table (everything except captions.)
|
/** nsTableFrame maps the inner portion of a table (everything except captions.)
|
||||||
|
@ -1077,9 +1077,9 @@ AC_Wrapup(nsTableFrame* aTableFrame,
|
|||||||
|
|
||||||
void
|
void
|
||||||
AC_Increase(PRInt32 aNumAutoCols,
|
AC_Increase(PRInt32 aNumAutoCols,
|
||||||
nsColInfo** aColInfo,
|
nsColInfo** aColInfo,
|
||||||
PRInt32 aDivisor,
|
PRInt32 aDivisor,
|
||||||
PRInt32& aAvailWidth)
|
PRInt32& aAvailWidth)
|
||||||
{
|
{
|
||||||
for (PRInt32 i = 0; i < aNumAutoCols; i++) {
|
for (PRInt32 i = 0; i < aNumAutoCols; i++) {
|
||||||
if ((aAvailWidth <= 0) || (aDivisor <= 0)) {
|
if ((aAvailWidth <= 0) || (aDivisor <= 0)) {
|
||||||
@ -1087,12 +1087,15 @@ AC_Increase(PRInt32 aNumAutoCols,
|
|||||||
}
|
}
|
||||||
float percent = ((float)aColInfo[i]->mMaxWidth) / (float)aDivisor;
|
float percent = ((float)aColInfo[i]->mMaxWidth) / (float)aDivisor;
|
||||||
aDivisor -= aColInfo[i]->mMaxWidth;
|
aDivisor -= aColInfo[i]->mMaxWidth;
|
||||||
nscoord addition = PR_MIN(aAvailWidth, NSToCoordRound(((float)(aAvailWidth)) * percent));
|
nscoord addition = NSToCoordRound(((float)(aAvailWidth)) * percent);
|
||||||
addition = PR_MIN(addition, aColInfo[i]->mMaxWidth - aColInfo[i]->mWidth);
|
// if its the last col, try to give what's left to it
|
||||||
// don't let the total additions exceed what is available
|
if ((i == aNumAutoCols - 1) && (addition < aAvailWidth)) {
|
||||||
if (i == aNumAutoCols - 1) {
|
addition = aAvailWidth;
|
||||||
addition = PR_MIN(addition, aAvailWidth);
|
|
||||||
}
|
}
|
||||||
|
// don't let the addition exceed what is available to add
|
||||||
|
addition = PR_MIN(addition, aAvailWidth);
|
||||||
|
// don't go over the col max
|
||||||
|
addition = PR_MIN(addition, aColInfo[i]->mMaxWidth - aColInfo[i]->mWidth);
|
||||||
aColInfo[i]->mWidth += addition;
|
aColInfo[i]->mWidth += addition;
|
||||||
aAvailWidth -= addition;
|
aAvailWidth -= addition;
|
||||||
}
|
}
|
||||||
@ -1100,9 +1103,9 @@ AC_Increase(PRInt32 aNumAutoCols,
|
|||||||
|
|
||||||
void
|
void
|
||||||
AC_Decrease(PRInt32 aNumAutoCols,
|
AC_Decrease(PRInt32 aNumAutoCols,
|
||||||
nsColInfo** aColInfo,
|
nsColInfo** aColInfo,
|
||||||
PRInt32 aDivisor,
|
PRInt32 aDivisor,
|
||||||
PRInt32& aExcess)
|
PRInt32& aExcess)
|
||||||
{
|
{
|
||||||
for (PRInt32 i = 0; i < aNumAutoCols; i++) {
|
for (PRInt32 i = 0; i < aNumAutoCols; i++) {
|
||||||
if ((aExcess <= 0) || (aDivisor <= 0)) {
|
if ((aExcess <= 0) || (aDivisor <= 0)) {
|
||||||
@ -1110,19 +1113,20 @@ AC_Decrease(PRInt32 aNumAutoCols,
|
|||||||
}
|
}
|
||||||
float percent = ((float)aColInfo[i]->mMaxWidth) / (float)aDivisor;
|
float percent = ((float)aColInfo[i]->mMaxWidth) / (float)aDivisor;
|
||||||
aDivisor -= aColInfo[i]->mMaxWidth;
|
aDivisor -= aColInfo[i]->mMaxWidth;
|
||||||
nscoord reduction = PR_MIN(aExcess, NSToCoordRound(((float)(aExcess)) * percent));
|
nscoord reduction = NSToCoordRound(((float)(aExcess)) * percent);
|
||||||
// don't go over the col min
|
// if its the last col, try to remove the remaining excess from it
|
||||||
reduction = PR_MIN(reduction, aColInfo[i]->mWidth - aColInfo[i]->mMinWidth);
|
if ((i == aNumAutoCols - 1) && (reduction < aExcess)) {
|
||||||
// don't let the total reductions exceed what is available
|
reduction = aExcess;
|
||||||
if (i == aNumAutoCols - 1) {
|
|
||||||
reduction = PR_MIN(reduction, aExcess);
|
|
||||||
}
|
}
|
||||||
|
// don't let the reduction exceed what is available to reduce
|
||||||
|
reduction = PR_MIN(reduction, aExcess);
|
||||||
|
// don't go under the col min
|
||||||
|
reduction = PR_MIN(reduction, aColInfo[i]->mWidth - aColInfo[i]->mMinWidth);
|
||||||
aColInfo[i]->mWidth -= reduction;
|
aColInfo[i]->mWidth -= reduction;
|
||||||
aExcess -= reduction;
|
aExcess -= reduction;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
AC_Sort(nsColInfo** aColInfo, PRInt32 aNumCols)
|
AC_Sort(nsColInfo** aColInfo, PRInt32 aNumCols)
|
||||||
{
|
{
|
||||||
|
@ -52,7 +52,6 @@ static PRBool DEBUG_REFLOW_ROWGRP = PR_FALSE;
|
|||||||
static PRBool DEBUG_REFLOW_ROW = PR_FALSE;
|
static PRBool DEBUG_REFLOW_ROW = PR_FALSE;
|
||||||
static PRBool DEBUG_REFLOW_CELL = PR_FALSE;
|
static PRBool DEBUG_REFLOW_CELL = PR_FALSE;
|
||||||
static PRBool DEBUG_REFLOW_AREA = PR_FALSE;
|
static PRBool DEBUG_REFLOW_AREA = PR_FALSE;
|
||||||
|
|
||||||
/* ============================================================================ */
|
/* ============================================================================ */
|
||||||
|
|
||||||
/** nsTableFrame maps the inner portion of a table (everything except captions.)
|
/** nsTableFrame maps the inner portion of a table (everything except captions.)
|
||||||
|
Loading…
Reference in New Issue
Block a user