| Index: Source/platform/fonts/GlyphBufferTest.cpp
|
| diff --git a/Source/platform/fonts/GlyphBufferTest.cpp b/Source/platform/fonts/GlyphBufferTest.cpp
|
| index d03c74de8c14760c5b3a74f9a098dc60c99f01d9..44297b1ae6f0e6c2d314d69f7bcfd94d20f10196 100644
|
| --- a/Source/platform/fonts/GlyphBufferTest.cpp
|
| +++ b/Source/platform/fonts/GlyphBufferTest.cpp
|
| @@ -47,10 +47,10 @@ TEST(GlyphBufferTest, StoresGlyphs)
|
| GlyphBuffer glyphBuffer;
|
| glyphBuffer.add(42, font1.get(), 10);
|
| glyphBuffer.add(43, font1.get(), 15);
|
| - glyphBuffer.add(44, font2.get(), 12);
|
| + glyphBuffer.add(44, font2.get(), 22);
|
|
|
| EXPECT_FALSE(glyphBuffer.isEmpty());
|
| - EXPECT_FALSE(glyphBuffer.hasOffsets());
|
| + EXPECT_FALSE(glyphBuffer.hasVerticalOffsets());
|
| EXPECT_EQ(3u, glyphBuffer.size());
|
|
|
| EXPECT_EQ(42, glyphBuffer.glyphAt(0));
|
| @@ -63,27 +63,39 @@ TEST(GlyphBufferTest, StoresGlyphs)
|
| EXPECT_EQ(44, glyphs[2]);
|
| }
|
|
|
| -TEST(GlyphBufferTest, StoresOffsets)
|
| +TEST(GlyphBufferTest, StoresVerticalOffsets)
|
| {
|
| RefPtr<SimpleFontData> font1 = TestSimpleFontData::create();
|
| RefPtr<SimpleFontData> font2 = TestSimpleFontData::create();
|
|
|
| GlyphBuffer glyphBuffer;
|
| - glyphBuffer.add(42, font1.get(), FloatSize(10, 0), 0);
|
| - glyphBuffer.add(43, font1.get(), FloatSize(15, 0), 0);
|
| - glyphBuffer.add(44, font2.get(), FloatSize(12, 2), 0);
|
| + EXPECT_FALSE(glyphBuffer.hasVerticalOffsets());
|
| +
|
| + glyphBuffer.add(42, font1.get(), FloatPoint(10, 0));
|
| + glyphBuffer.add(43, font1.get(), FloatPoint(15, 0));
|
| + glyphBuffer.add(44, font2.get(), FloatPoint(12, 2));
|
|
|
| EXPECT_FALSE(glyphBuffer.isEmpty());
|
| - EXPECT_TRUE(glyphBuffer.hasOffsets());
|
| + EXPECT_TRUE(glyphBuffer.hasVerticalOffsets());
|
| EXPECT_EQ(3u, glyphBuffer.size());
|
|
|
| - const FloatSize* offsets = glyphBuffer.offsets(0);
|
| - EXPECT_EQ(FloatSize(10, 0), offsets[0]);
|
| - EXPECT_EQ(FloatSize(15, 0), offsets[1]);
|
| - EXPECT_EQ(FloatSize(12, 2), offsets[2]);
|
| + const float* offsets = glyphBuffer.offsets(0);
|
| + EXPECT_EQ(10, glyphBuffer.xOffsetAt(0));
|
| + EXPECT_EQ(0, glyphBuffer.yOffsetAt(0));
|
| + EXPECT_EQ(15, glyphBuffer.xOffsetAt(1));
|
| + EXPECT_EQ(0, glyphBuffer.yOffsetAt(1));
|
| + EXPECT_EQ(12, glyphBuffer.xOffsetAt(2));
|
| + EXPECT_EQ(2, glyphBuffer.yOffsetAt(2));
|
| +
|
| + EXPECT_EQ(10, offsets[0]);
|
| + EXPECT_EQ(0, offsets[1]);
|
| + EXPECT_EQ(15, offsets[2]);
|
| + EXPECT_EQ(0, offsets[3]);
|
| + EXPECT_EQ(12, offsets[4]);
|
| + EXPECT_EQ(2, offsets[5]);
|
| }
|
|
|
| -TEST(GlyphBufferTest, StoresAdvances)
|
| +TEST(GlyphBufferTest, StoresOffsets)
|
| {
|
| RefPtr<SimpleFontData> font1 = TestSimpleFontData::create();
|
| RefPtr<SimpleFontData> font2 = TestSimpleFontData::create();
|
| @@ -94,16 +106,17 @@ TEST(GlyphBufferTest, StoresAdvances)
|
| glyphBuffer.add(44, font2.get(), 20);
|
|
|
| EXPECT_FALSE(glyphBuffer.isEmpty());
|
| + EXPECT_FALSE(glyphBuffer.hasVerticalOffsets());
|
| EXPECT_EQ(3u, glyphBuffer.size());
|
|
|
| - EXPECT_EQ(10, glyphBuffer.advanceAt(0));
|
| - EXPECT_EQ(15, glyphBuffer.advanceAt(1));
|
| - EXPECT_EQ(20, glyphBuffer.advanceAt(2));
|
| + EXPECT_EQ(10, glyphBuffer.xOffsetAt(0));
|
| + EXPECT_EQ(15, glyphBuffer.xOffsetAt(1));
|
| + EXPECT_EQ(20, glyphBuffer.xOffsetAt(2));
|
|
|
| - const float* advances = glyphBuffer.advances(0);
|
| - EXPECT_EQ(10, advances[0]);
|
| - EXPECT_EQ(15, advances[1]);
|
| - EXPECT_EQ(20, advances[2]);
|
| + const float* offsets = glyphBuffer.offsets(0);
|
| + EXPECT_EQ(10, offsets[0]);
|
| + EXPECT_EQ(15, offsets[1]);
|
| + EXPECT_EQ(20, offsets[2]);
|
| }
|
|
|
| TEST(GlyphBufferTest, StoresSimpleFontData)
|
| @@ -142,25 +155,45 @@ TEST(GlyphBufferTest, GlyphArrayWithOffset)
|
| EXPECT_EQ(44, glyphs[1]);
|
| }
|
|
|
| -TEST(GlyphBufferTest, AdvanceArrayWithOffset)
|
| +TEST(GlyphBufferTest, OffsetArrayWithNonZeroIndex)
|
| {
|
| RefPtr<SimpleFontData> font1 = TestSimpleFontData::create();
|
| RefPtr<SimpleFontData> font2 = TestSimpleFontData::create();
|
|
|
| - GlyphBuffer glyphBuffer;
|
| - glyphBuffer.add(42, font1.get(), 10);
|
| - glyphBuffer.add(43, font1.get(), 15);
|
| - glyphBuffer.add(43, font1.get(), 12);
|
| -
|
| - EXPECT_FALSE(glyphBuffer.isEmpty());
|
| - EXPECT_EQ(3u, glyphBuffer.size());
|
| + {
|
| + GlyphBuffer glyphBuffer;
|
| + glyphBuffer.add(42, font1.get(), 10);
|
| + glyphBuffer.add(43, font1.get(), 15);
|
| + glyphBuffer.add(43, font2.get(), 12);
|
| +
|
| + EXPECT_FALSE(glyphBuffer.isEmpty());
|
| + EXPECT_FALSE(glyphBuffer.hasVerticalOffsets());
|
| + EXPECT_EQ(3u, glyphBuffer.size());
|
| +
|
| + const float* offsets = glyphBuffer.offsets(1);
|
| + EXPECT_EQ(15, offsets[0]);
|
| + EXPECT_EQ(12, offsets[1]);
|
| + }
|
|
|
| - const float* advances = glyphBuffer.advances(1);
|
| - EXPECT_EQ(15, advances[0]);
|
| - EXPECT_EQ(12, advances[1]);
|
| + {
|
| + GlyphBuffer glyphBuffer;
|
| + glyphBuffer.add(42, font1.get(), FloatPoint(10, 0));
|
| + glyphBuffer.add(43, font1.get(), FloatPoint(15, 0));
|
| + glyphBuffer.add(43, font2.get(), FloatPoint(12, 2));
|
| +
|
| + EXPECT_FALSE(glyphBuffer.isEmpty());
|
| + EXPECT_TRUE(glyphBuffer.hasVerticalOffsets());
|
| + EXPECT_EQ(3u, glyphBuffer.size());
|
| +
|
| + const float* offsets = glyphBuffer.offsets(1);
|
| + EXPECT_EQ(15, offsets[0]);
|
| + EXPECT_EQ(0, offsets[1]);
|
| + EXPECT_EQ(12, offsets[2]);
|
| + EXPECT_EQ(2, offsets[3]);
|
| + }
|
| }
|
|
|
| -TEST(GlyphBufferTest, Reverse)
|
| +TEST(GlyphBufferTest, ReverseForSimpleRTL)
|
| {
|
| RefPtr<SimpleFontData> font1 = TestSimpleFontData::create();
|
| RefPtr<SimpleFontData> font2 = TestSimpleFontData::create();
|
| @@ -168,38 +201,24 @@ TEST(GlyphBufferTest, Reverse)
|
| GlyphBuffer glyphBuffer;
|
| glyphBuffer.add(42, font1.get(), 10);
|
| glyphBuffer.add(43, font1.get(), 15);
|
| - glyphBuffer.add(44, font2.get(), 20);
|
| + glyphBuffer.add(44, font2.get(), 25);
|
|
|
| EXPECT_FALSE(glyphBuffer.isEmpty());
|
| EXPECT_EQ(3u, glyphBuffer.size());
|
|
|
| - glyphBuffer.reverse();
|
| + glyphBuffer.reverseForSimpleRTL(30, 100);
|
|
|
| EXPECT_FALSE(glyphBuffer.isEmpty());
|
| EXPECT_EQ(3u, glyphBuffer.size());
|
| EXPECT_EQ(44, glyphBuffer.glyphAt(0));
|
| EXPECT_EQ(43, glyphBuffer.glyphAt(1));
|
| EXPECT_EQ(42, glyphBuffer.glyphAt(2));
|
| - EXPECT_EQ(20, glyphBuffer.advanceAt(0));
|
| - EXPECT_EQ(15, glyphBuffer.advanceAt(1));
|
| - EXPECT_EQ(10, glyphBuffer.advanceAt(2));
|
| EXPECT_EQ(font2.get(), glyphBuffer.fontDataAt(0));
|
| EXPECT_EQ(font1.get(), glyphBuffer.fontDataAt(1));
|
| EXPECT_EQ(font1.get(), glyphBuffer.fontDataAt(2));
|
| -}
|
| -
|
| -TEST(GlyphBufferTest, ExpandLastAdvance)
|
| -{
|
| - RefPtr<SimpleFontData> font1 = TestSimpleFontData::create();
|
| - RefPtr<SimpleFontData> font2 = TestSimpleFontData::create();
|
| -
|
| - GlyphBuffer glyphBuffer;
|
| - glyphBuffer.add(42, font1.get(), 10);
|
| - glyphBuffer.add(43, font1.get(), 15);
|
| - glyphBuffer.add(44, font2.get(), 12);
|
| -
|
| - glyphBuffer.expandLastAdvance(20);
|
| - EXPECT_EQ(32, glyphBuffer.advanceAt(2));
|
| + EXPECT_EQ(70, glyphBuffer.xOffsetAt(0));
|
| + EXPECT_EQ(75, glyphBuffer.xOffsetAt(1));
|
| + EXPECT_EQ(85, glyphBuffer.xOffsetAt(2));
|
| }
|
|
|
| } // namespace
|
|
|