Bug 1038663 (part 3, attempt 2) - Factor out space width computation. r=heycam.

This commit is contained in:
Nicholas Nethercote 2015-11-08 14:48:58 -08:00
parent a34dc73523
commit 163196360e

View file

@ -1607,6 +1607,19 @@ GetFirstFontMetrics(gfxFontGroup* aFontGroup, bool aVerticalMetrics)
: gfxFont::eHorizontal); : gfxFont::eHorizontal);
} }
static gfxFloat
GetSpaceWidthAppUnits(gfxTextRun* aTextRun)
{
// Round the space width when converting to appunits the same way textruns
// do.
gfxFloat spaceWidthAppUnits =
NS_round(GetFirstFontMetrics(aTextRun->GetFontGroup(),
aTextRun->UseCenterBaseline()).spaceWidth *
aTextRun->GetAppUnitsPerDevUnit());
return spaceWidthAppUnits;
}
static nscoord static nscoord
LetterSpacing(nsIFrame* aFrame, const nsStyleText* aStyleText = nullptr) LetterSpacing(nsIFrame* aFrame, const nsStyleText* aStyleText = nullptr)
{ {
@ -3225,14 +3238,8 @@ ComputeTabWidthAppUnits(nsIFrame* aFrame, gfxTextRun* aTextRun)
{ {
// Get the number of spaces from CSS -moz-tab-size // Get the number of spaces from CSS -moz-tab-size
const nsStyleText* textStyle = aFrame->StyleText(); const nsStyleText* textStyle = aFrame->StyleText();
// Round the space width when converting to appunits the same way return textStyle->mTabSize * GetSpaceWidthAppUnits(aTextRun);
// textruns do
gfxFloat spaceWidthAppUnits =
NS_round(GetFirstFontMetrics(aTextRun->GetFontGroup(),
aTextRun->UseCenterBaseline()).spaceWidth *
aTextRun->GetAppUnitsPerDevUnit());
return textStyle->mTabSize * spaceWidthAppUnits;
} }
// aX and the result are in whole appunits. // aX and the result are in whole appunits.