Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(680)

Unified Diff: third_party/WebKit/Source/core/layout/ng/ng_inline_node_test.cc

Issue 2563403002: [LayoutNG] Add Bidi reordering and fill in NGPhysicalTextFragment (Closed)
Patch Set: ikilpatrick review Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/core/layout/ng/ng_inline_node_test.cc
diff --git a/third_party/WebKit/Source/core/layout/ng/ng_inline_node_test.cc b/third_party/WebKit/Source/core/layout/ng/ng_inline_node_test.cc
index ad9bd2487eed0f17ed49d7671340eda4454959be..18cf2e897e582bef2388b9bf9a94b7863b686e0d 100644
--- a/third_party/WebKit/Source/core/layout/ng/ng_inline_node_test.cc
+++ b/third_party/WebKit/Source/core/layout/ng/ng_inline_node_test.cc
@@ -4,13 +4,17 @@
#include "core/layout/ng/ng_inline_node.h"
+#include "core/layout/ng/ng_constraint_space.h"
+#include "core/layout/ng/ng_constraint_space_builder.h"
+#include "core/layout/ng/ng_fragment_builder.h"
+#include "core/layout/ng/ng_physical_text_fragment.h"
+#include "core/layout/ng/ng_text_fragment.h"
+#include "core/layout/ng/ng_text_layout_algorithm.h"
#include "core/style/ComputedStyle.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace blink {
-namespace {
-
class NGInlineNodeForTest : public NGInlineNode {
public:
NGInlineNodeForTest(const ComputedStyle* block_style) {
@@ -21,14 +25,17 @@ class NGInlineNodeForTest : public NGInlineNode {
String& Text() { return text_content_; }
Vector<NGLayoutInlineItem>& Items() { return items_; }
- void AppendText(const String& text) {
+ void Append(const String& text, const ComputedStyle* style = nullptr) {
unsigned start = text_content_.length();
text_content_.append(text);
- items_.emplace_back(start, start + text.length(), nullptr);
+ items_.append(NGLayoutInlineItem(start, start + text.length(), style));
}
- void AppendText(const char16_t* text) {
- AppendText(String(reinterpret_cast<const UChar*>(text)));
+ void Append(UChar character) {
+ text_content_.append(character);
+ unsigned end = text_content_.length();
+ items_.append(NGLayoutInlineItem(end - 1, end, nullptr));
+ is_bidi_enabled_ = true;
}
void ClearText() {
@@ -36,77 +43,157 @@ class NGInlineNodeForTest : public NGInlineNode {
items_.clear();
}
- void SegmentText() { NGInlineNode::SegmentText(); }
+ void SegmentText() {
+ is_bidi_enabled_ = true;
+ NGInlineNode::SegmentText();
+ }
+};
+
+class NGInlineNodeTest : public ::testing::Test {
+ protected:
+ void SetUp() override { style_ = ComputedStyle::create(); }
+
+ void CreateLine(NGInlineNode* node,
+ unsigned start_index,
+ unsigned end_index,
+ HeapVector<Member<NGPhysicalTextFragment>>* fragments_out) {
+ NGConstraintSpace* constraint_space =
+ NGConstraintSpaceBuilder(kHorizontalTopBottom).ToConstraintSpace();
+ HeapVector<Member<NGFragmentBase>> fragments;
+ Vector<NGLogicalOffset> logical_offsets;
+ NGTextLayoutAlgorithm* algorithm =
+ new NGTextLayoutAlgorithm(node, nullptr, nullptr);
+ algorithm->CreateLine(node->Items(start_index, end_index),
+ *constraint_space, &fragments, &logical_offsets);
+ for (const NGFragmentBase* fragment : fragments) {
+ fragments_out->append(
+ toNGPhysicalTextFragment(fragment->PhysicalFragment()));
+ }
+ }
+
+ RefPtr<ComputedStyle> style_;
};
-class NGInlineNodeTest : public ::testing::Test {};
+#define TEST_ITEM_OFFSET_DIR(item, start, end, direction) \
+ EXPECT_EQ(start, item.StartOffset()); \
+ EXPECT_EQ(end, item.EndOffset()); \
+ EXPECT_EQ(direction, item.Direction())
TEST_F(NGInlineNodeTest, SegmentASCII) {
- RefPtr<ComputedStyle> style = ComputedStyle::create();
- NGInlineNodeForTest* box = new NGInlineNodeForTest(style.get());
- box->AppendText("Hello");
- box->SegmentText();
- ASSERT_EQ(1u, box->Items().size());
- NGLayoutInlineItem& item = box->Items()[0];
- EXPECT_EQ(0u, item.StartOffset());
- EXPECT_EQ(5u, item.EndOffset());
- EXPECT_EQ(LTR, item.Direction());
+ NGInlineNodeForTest* node = new NGInlineNodeForTest(style_.get());
+ node->Append("Hello");
+ node->SegmentText();
+ Vector<NGLayoutInlineItem>& items = node->Items();
+ ASSERT_EQ(1u, items.size());
+ TEST_ITEM_OFFSET_DIR(items[0], 0u, 5u, LTR);
}
TEST_F(NGInlineNodeTest, SegmentHebrew) {
- RefPtr<ComputedStyle> style = ComputedStyle::create();
- NGInlineNodeForTest* box = new NGInlineNodeForTest(style.get());
- box->AppendText(u"\u05E2\u05D1\u05E8\u05D9\u05EA");
- box->SegmentText();
- ASSERT_EQ(1u, box->Items().size());
- NGLayoutInlineItem& item = box->Items()[0];
- EXPECT_EQ(0u, item.StartOffset());
- EXPECT_EQ(5u, item.EndOffset());
- EXPECT_EQ(RTL, item.Direction());
+ NGInlineNodeForTest* node = new NGInlineNodeForTest(style_.get());
+ node->Append(u"\u05E2\u05D1\u05E8\u05D9\u05EA");
+ node->SegmentText();
+ ASSERT_EQ(1u, node->Items().size());
+ Vector<NGLayoutInlineItem>& items = node->Items();
+ ASSERT_EQ(1u, items.size());
+ TEST_ITEM_OFFSET_DIR(items[0], 0u, 5u, RTL);
}
TEST_F(NGInlineNodeTest, SegmentSplit1To2) {
- RefPtr<ComputedStyle> style = ComputedStyle::create();
- NGInlineNodeForTest* box = new NGInlineNodeForTest(style.get());
- box->AppendText(u"Hello \u05E2\u05D1\u05E8\u05D9\u05EA");
- box->SegmentText();
- ASSERT_EQ(2u, box->Items().size());
- NGLayoutInlineItem& item = box->Items()[0];
- EXPECT_EQ(0u, item.StartOffset());
- EXPECT_EQ(6u, item.EndOffset());
- EXPECT_EQ(LTR, item.Direction());
- item = box->Items()[1];
- EXPECT_EQ(6u, item.StartOffset());
- EXPECT_EQ(11u, item.EndOffset());
- EXPECT_EQ(RTL, item.Direction());
+ NGInlineNodeForTest* node = new NGInlineNodeForTest(style_.get());
+ node->Append(u"Hello \u05E2\u05D1\u05E8\u05D9\u05EA");
+ node->SegmentText();
+ ASSERT_EQ(2u, node->Items().size());
+ Vector<NGLayoutInlineItem>& items = node->Items();
+ ASSERT_EQ(2u, items.size());
+ TEST_ITEM_OFFSET_DIR(items[0], 0u, 6u, LTR);
+ TEST_ITEM_OFFSET_DIR(items[1], 6u, 11u, RTL);
}
TEST_F(NGInlineNodeTest, SegmentSplit3To4) {
- RefPtr<ComputedStyle> style = ComputedStyle::create();
- NGInlineNodeForTest* box = new NGInlineNodeForTest(style.get());
- box->AppendText("Hel");
- box->AppendText(u"lo \u05E2");
- box->AppendText(u"\u05D1\u05E8\u05D9\u05EA");
- box->SegmentText();
- ASSERT_EQ(4u, box->Items().size());
- NGLayoutInlineItem& item = box->Items()[0];
- EXPECT_EQ(0u, item.StartOffset());
- EXPECT_EQ(3u, item.EndOffset());
- EXPECT_EQ(LTR, item.Direction());
- item = box->Items()[1];
- EXPECT_EQ(3u, item.StartOffset());
- EXPECT_EQ(6u, item.EndOffset());
- EXPECT_EQ(LTR, item.Direction());
- item = box->Items()[2];
- EXPECT_EQ(6u, item.StartOffset());
- EXPECT_EQ(7u, item.EndOffset());
- EXPECT_EQ(RTL, item.Direction());
- item = box->Items()[3];
- EXPECT_EQ(7u, item.StartOffset());
- EXPECT_EQ(11u, item.EndOffset());
- EXPECT_EQ(RTL, item.Direction());
+ NGInlineNodeForTest* node = new NGInlineNodeForTest(style_.get());
+ node->Append("Hel");
+ node->Append(u"lo \u05E2");
+ node->Append(u"\u05D1\u05E8\u05D9\u05EA");
+ node->SegmentText();
+ Vector<NGLayoutInlineItem>& items = node->Items();
+ ASSERT_EQ(4u, items.size());
+ TEST_ITEM_OFFSET_DIR(items[0], 0u, 3u, LTR);
+ TEST_ITEM_OFFSET_DIR(items[1], 3u, 6u, LTR);
+ TEST_ITEM_OFFSET_DIR(items[2], 6u, 7u, RTL);
+ TEST_ITEM_OFFSET_DIR(items[3], 7u, 11u, RTL);
+}
+
+TEST_F(NGInlineNodeTest, SegmentBidiOverride) {
+ NGInlineNodeForTest* node = new NGInlineNodeForTest(style_.get());
+ node->Append("Hello ");
+ node->Append(rightToLeftOverrideCharacter);
+ node->Append("ABC");
+ node->Append(popDirectionalFormattingCharacter);
+ node->SegmentText();
+ Vector<NGLayoutInlineItem>& items = node->Items();
+ ASSERT_EQ(4u, items.size());
+ TEST_ITEM_OFFSET_DIR(items[0], 0u, 6u, LTR);
+ TEST_ITEM_OFFSET_DIR(items[1], 6u, 7u, RTL);
+ TEST_ITEM_OFFSET_DIR(items[2], 7u, 10u, RTL);
+ TEST_ITEM_OFFSET_DIR(items[3], 10u, 11u, LTR);
}
-} // namespace
+static NGInlineNodeForTest* CreateBidiIsolateNode(const ComputedStyle* style) {
+ NGInlineNodeForTest* node = new NGInlineNodeForTest(style);
+ node->Append("Hello ", style);
+ node->Append(rightToLeftIsolateCharacter);
+ node->Append(u"\u05E2\u05D1\u05E8\u05D9\u05EA ", style);
+ node->Append(leftToRightIsolateCharacter);
+ node->Append("A", style);
+ node->Append(popDirectionalIsolateCharacter);
+ node->Append(u"\u05E2\u05D1\u05E8\u05D9\u05EA", style);
+ node->Append(popDirectionalIsolateCharacter);
+ node->Append(" World", style);
+ node->SegmentText();
+ return node;
+}
+
+TEST_F(NGInlineNodeTest, SegmentBidiIsolate) {
+ NGInlineNodeForTest* node = CreateBidiIsolateNode(style_.get());
+ Vector<NGLayoutInlineItem>& items = node->Items();
+ ASSERT_EQ(9u, items.size());
+ TEST_ITEM_OFFSET_DIR(items[0], 0u, 6u, LTR);
+ TEST_ITEM_OFFSET_DIR(items[1], 6u, 7u, LTR);
+ TEST_ITEM_OFFSET_DIR(items[2], 7u, 13u, RTL);
+ TEST_ITEM_OFFSET_DIR(items[3], 13u, 14u, RTL);
+ TEST_ITEM_OFFSET_DIR(items[4], 14u, 15u, LTR);
+ TEST_ITEM_OFFSET_DIR(items[5], 15u, 16u, RTL);
+ TEST_ITEM_OFFSET_DIR(items[6], 16u, 21u, RTL);
+ TEST_ITEM_OFFSET_DIR(items[7], 21u, 22u, LTR);
+ TEST_ITEM_OFFSET_DIR(items[8], 22u, 28u, LTR);
+}
+
+#define TEST_TEXT_FRAGMENT(fragment, node, start_index, end_index, dir) \
+ EXPECT_EQ(node, fragment->Node()); \
+ EXPECT_EQ(start_index, fragment->StartIndex()); \
+ EXPECT_EQ(end_index, fragment->EndIndex()); \
+ EXPECT_EQ(dir, node->Items()[fragment->StartIndex()].Direction())
+
+TEST_F(NGInlineNodeTest, CreateLineBidiIsolate) {
+ NGInlineNodeForTest* node = CreateBidiIsolateNode(style_.get());
+ HeapVector<Member<NGPhysicalTextFragment>> fragments;
+ CreateLine(node, 0, node->Items().size(), &fragments);
+ ASSERT_EQ(5u, fragments.size());
+ TEST_TEXT_FRAGMENT(fragments[0], node, 0u, 1u, LTR);
+ TEST_TEXT_FRAGMENT(fragments[1], node, 6u, 7u, RTL);
+ TEST_TEXT_FRAGMENT(fragments[2], node, 4u, 5u, LTR);
+ TEST_TEXT_FRAGMENT(fragments[3], node, 2u, 3u, RTL);
+ TEST_TEXT_FRAGMENT(fragments[4], node, 8u, 9u, LTR);
+}
+
+TEST_F(NGInlineNodeTest, CreateLineRangeBidiIsolate) {
+ NGInlineNodeForTest* node = CreateBidiIsolateNode(style_.get());
+ HeapVector<Member<NGPhysicalTextFragment>> fragments;
+ CreateLine(node, 2, 7, &fragments);
+ ASSERT_EQ(3u, fragments.size());
+ TEST_TEXT_FRAGMENT(fragments[0], node, 6u, 7u, RTL);
+ TEST_TEXT_FRAGMENT(fragments[1], node, 4u, 5u, LTR);
+ TEST_TEXT_FRAGMENT(fragments[2], node, 2u, 3u, RTL);
+}
} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698