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

Unified Diff: third_party/WebKit/Source/core/layout/ng/ng_units.h

Issue 2651853002: Deprecate the currently used NGMarginStrut in favor of the new one. (Closed)
Patch Set: move NGLogicalSize,NGLogicalOffset "for tests" constructors to private Created 3 years, 11 months 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_units.h
diff --git a/third_party/WebKit/Source/core/layout/ng/ng_units.h b/third_party/WebKit/Source/core/layout/ng/ng_units.h
index 63bd0b37175a569d88d98a42e5479cdf1c1e5a96..9433440e71811a45a354d6af68d5f3fc16539d5e 100644
--- a/third_party/WebKit/Source/core/layout/ng/ng_units.h
+++ b/third_party/WebKit/Source/core/layout/ng/ng_units.h
@@ -44,6 +44,12 @@ struct NGLogicalSize {
bool IsEmpty() const {
return inline_size == LayoutUnit() || block_size == LayoutUnit();
}
+
+ private:
+ friend class NGBlockLayoutAlgorithmTest;
ikilpatrick 2017/01/24 00:22:13 can you ad a comment here as to why friend class?
Gleb Lanbin 2017/01/24 04:38:02 Done.
+ NGLogicalSize(int inline_size, int block_size)
+ : inline_size(LayoutUnit(inline_size)),
+ block_size(LayoutUnit(block_size)) {}
};
inline std::ostream& operator<<(std::ostream& stream,
@@ -77,9 +83,11 @@ struct NGLogicalOffset {
bool operator==(const NGLogicalOffset& other) const;
NGLogicalOffset operator+(const NGLogicalOffset& other) const;
-
NGLogicalOffset& operator+=(const NGLogicalOffset& other);
+ NGLogicalOffset operator-(const NGLogicalOffset& other) const;
+ NGLogicalOffset& operator-=(const NGLogicalOffset& other);
+
bool operator>(const NGLogicalOffset& other) const;
bool operator>=(const NGLogicalOffset& other) const;
@@ -87,6 +95,12 @@ struct NGLogicalOffset {
bool operator<=(const NGLogicalOffset& other) const;
String ToString() const;
+
+ private:
+ friend class NGBlockLayoutAlgorithmTest;
ikilpatrick 2017/01/24 00:22:13 as above.
Gleb Lanbin 2017/01/24 04:38:02 Done.
+ NGLogicalOffset(int inline_offset, int block_offset)
+ : inline_offset(LayoutUnit(inline_offset)),
+ block_offset(LayoutUnit(block_offset)) {}
};
CORE_EXPORT inline std::ostream& operator<<(std::ostream& os,
@@ -105,8 +119,13 @@ struct NGPhysicalOffset {
NGPhysicalOffset operator+(const NGPhysicalOffset& other) const;
NGPhysicalOffset& operator+=(const NGPhysicalOffset& other);
+
NGPhysicalOffset operator-(const NGPhysicalOffset& other) const;
NGPhysicalOffset& operator-=(const NGPhysicalOffset& other);
+
+ String ToString() const {
+ return String::format("%dx%d", left.toInt(), top.toInt());
+ }
};
struct NGPhysicalSize {
@@ -139,6 +158,8 @@ struct NGPhysicalRect {
// TODO(glebl): move to a separate file in layout/ng/units.
struct CORE_EXPORT NGLogicalRect {
NGLogicalRect() {}
+ NGLogicalRect(const NGLogicalOffset& offset, const NGLogicalSize& size)
+ : offset(offset), size(size) {}
NGLogicalRect(LayoutUnit inline_offset,
LayoutUnit block_offset,
LayoutUnit inline_size,
@@ -197,8 +218,16 @@ struct CORE_EXPORT NGExclusion {
// Type of this exclusion.
Type type;
+
+ bool operator==(const NGExclusion& other) const;
+ String ToString() const;
};
+inline std::ostream& operator<<(std::ostream& stream,
+ const NGExclusion& value) {
+ return stream << value.ToString();
+}
+
struct CORE_EXPORT NGExclusions {
// Default constructor.
NGExclusions();
@@ -266,10 +295,21 @@ struct CORE_EXPORT NGBoxStrut {
}
bool operator==(const NGBoxStrut& other) const;
+
+ String ToString() const {
+ return String::format("Inline: (%d %d) Block: (%d %d)",
+ inline_start.toInt(), inline_end.toInt(),
+ block_start.toInt(), block_end.toInt());
+ }
};
+inline std::ostream& operator<<(std::ostream& stream, const NGBoxStrut& value) {
+ return stream << value.ToString();
+}
+
// This struct is used for the margin collapsing calculation.
-struct CORE_EXPORT NGMarginStrut {
+// TODO(glebl): Deprecated. It's being replaced by NGMarginStrut
+struct CORE_EXPORT NGDeprecatedMarginStrut {
LayoutUnit margin_block_start;
LayoutUnit margin_block_end;
@@ -287,7 +327,23 @@ struct CORE_EXPORT NGMarginStrut {
String ToString() const;
+ bool operator==(const NGDeprecatedMarginStrut& other) const;
+};
+
+// This struct is used for the margin collapsing calculation.
+struct CORE_EXPORT NGMarginStrut {
+ LayoutUnit margin;
+ LayoutUnit negative_margin;
+
bool operator==(const NGMarginStrut& other) const;
+
+ void Append(const LayoutUnit& value);
+
+ LayoutUnit Collapse() const;
+
+ LayoutUnit CollapseWith(const NGMarginStrut& other) const;
+
+ String ToString() const;
};
inline std::ostream& operator<<(std::ostream& stream,

Powered by Google App Engine
This is Rietveld 408576698