[css-grid] Remove compilation flag ENABLE_CSS_GRID_LAYOUT
[WebKit-https.git] / Source / WebCore / rendering / style / GridPosition.h
index 3f8fe97..7190c4c 100644 (file)
@@ -1,5 +1,6 @@
 /*
  * Copyright (C) 2012 Google Inc. All rights reserved.
+ * Copyright (C) 2013, 2014 Igalia S.L.
  *
  * Redistribution and use in source and binary forms, with or without
  * modification, are permitted provided that the following conditions are
  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  */
 
-#ifndef GridPosition_h
-#define GridPosition_h
+#pragma once
+
+#include <wtf/text/WTFString.h>
 
 namespace WebCore {
 
+// Recommended maximum size for both explicit and implicit grids.
+const int kGridMaxTracks = 1000000;
+
 enum GridPositionType {
     AutoPosition,
-    IntegerPosition
+    ExplicitPosition, // [ <integer> || <string> ]
+    SpanPosition, // span && [ <integer> || <string> ]
+    NamedGridAreaPosition // <ident>
+};
+
+enum GridPositionSide {
+    ColumnStartSide,
+    ColumnEndSide,
+    RowStartSide,
+    RowEndSide
 };
 
 class GridPosition {
@@ -50,30 +64,75 @@ public:
 
     GridPositionType type() const { return m_type; }
     bool isAuto() const { return m_type == AutoPosition; }
+    bool isSpan() const { return m_type == SpanPosition; }
+    bool isNamedGridArea() const { return m_type == NamedGridAreaPosition; }
+
+    void setExplicitPosition(int position, const String& namedGridLine)
+    {
+        m_type = ExplicitPosition;
+        setIntegerPosition(position);
+        m_namedGridLine = namedGridLine;
+    }
 
-    void setIntegerPosition(int position)
+    void setAutoPosition()
     {
-        m_type = IntegerPosition;
-        m_integerPosition = position;
+        m_type = AutoPosition;
+        m_integerPosition = 0;
+    }
+
+    // 'span' values cannot be negative, yet we reuse the <integer> position which can
+    // be. This means that we have to convert the span position to an integer, losing
+    // some precision here. It shouldn't be an issue in practice though.
+    void setSpanPosition(int position, const String& namedGridLine)
+    {
+        m_type = SpanPosition;
+        setIntegerPosition(position);
+        m_namedGridLine = namedGridLine;
+    }
+
+    void setNamedGridArea(const String& namedGridArea)
+    {
+        m_type = NamedGridAreaPosition;
+        m_namedGridLine = namedGridArea;
     }
 
     int integerPosition() const
     {
-        ASSERT(type() == IntegerPosition);
+        ASSERT(type() == ExplicitPosition);
+        return m_integerPosition;
+    }
+
+    String namedGridLine() const
+    {
+        ASSERT(type() == ExplicitPosition || type() == SpanPosition || type() == NamedGridAreaPosition);
+        return m_namedGridLine;
+    }
+
+    int spanPosition() const
+    {
+        ASSERT(type() == SpanPosition);
         return m_integerPosition;
     }
 
     bool operator==(const GridPosition& other) const
     {
-        return m_type == other.m_type && m_integerPosition == other.m_integerPosition;
+        return m_type == other.m_type && m_integerPosition == other.m_integerPosition && m_namedGridLine == other.m_namedGridLine;
+    }
+
+    bool shouldBeResolvedAgainstOppositePosition() const
+    {
+        return isAuto() || isSpan();
     }
 
 private:
+    void setIntegerPosition(int integerPosition)
+    {
+        m_integerPosition = clampTo(integerPosition, -kGridMaxTracks, kGridMaxTracks);
+    }
+
     GridPositionType m_type;
-    // FIXME: This should probably be a size_t but the spec currently allows any <integer>.
     int m_integerPosition;
+    String m_namedGridLine;
 };
 
 } // namespace WebCore
-
-#endif // GridPosition_h