Title: [141499] trunk/Source
Revision
141499
Author
[email protected]
Date
2013-01-31 15:49:26 -0800 (Thu, 31 Jan 2013)

Log Message

Abstraction for hiding enum class.
https://bugs.webkit.org/show_bug.cgi?id=108533

Reviewed by Anders Carlsson.

../WebCore: 

No new tests.

* Modules/webdatabase/DatabaseError.h:
(WebCore::ENUM_CLASS_BEGIN):

../WTF: 

* wtf/Compiler.h:
* wtf/EnumClass.h: Copied from Source/WTF/wtf/TypeSafeEnum.h.
(WTF::EnumClass::EnumClass):
(WTF::EnumClass::operator==):
(WTF::EnumClass::operator!=):
(WTF::EnumClass::operator<):
(WTF::EnumClass::operator<=):
(WTF::EnumClass::operator>):
(WTF::EnumClass::operator>=):
* wtf/TypeSafeEnum.h: Removed.

Modified Paths

Added Paths

Removed Paths

Diff

Modified: trunk/Source/WTF/ChangeLog (141498 => 141499)


--- trunk/Source/WTF/ChangeLog	2013-01-31 23:46:03 UTC (rev 141498)
+++ trunk/Source/WTF/ChangeLog	2013-01-31 23:49:26 UTC (rev 141499)
@@ -1,3 +1,21 @@
+2013-01-31  Mark Lam  <[email protected]>
+
+        Abstraction for hiding enum class.
+        https://bugs.webkit.org/show_bug.cgi?id=108533
+
+        Reviewed by Anders Carlsson.
+
+        * wtf/Compiler.h:
+        * wtf/EnumClass.h: Copied from Source/WTF/wtf/TypeSafeEnum.h.
+        (WTF::EnumClass::EnumClass):
+        (WTF::EnumClass::operator==):
+        (WTF::EnumClass::operator!=):
+        (WTF::EnumClass::operator<):
+        (WTF::EnumClass::operator<=):
+        (WTF::EnumClass::operator>):
+        (WTF::EnumClass::operator>=):
+        * wtf/TypeSafeEnum.h: Removed.
+
 2013-01-31  Andreas Kling  <[email protected]>
 
         Vector should consult allocator about ideal size when choosing capacity.

Modified: trunk/Source/WTF/wtf/Compiler.h (141498 => 141499)


--- trunk/Source/WTF/wtf/Compiler.h	2013-01-31 23:46:03 UTC (rev 141498)
+++ trunk/Source/WTF/wtf/Compiler.h	2013-01-31 23:49:26 UTC (rev 141499)
@@ -62,6 +62,7 @@
 #define WTF_COMPILER_SUPPORTS_C_STATIC_ASSERT __has_extension(c_static_assert)
 #define WTF_COMPILER_SUPPORTS_CXX_OVERRIDE_CONTROL __has_extension(cxx_override_control)
 #define WTF_COMPILER_SUPPORTS_HAS_TRIVIAL_DESTRUCTOR __has_extension(has_trivial_destructor)
+#define WTF_COMPILER_SUPPORTS_CXX_STRONG_ENUMS __has_extension(cxx_strong_enums)
 
 #endif
 

Copied: trunk/Source/WTF/wtf/EnumClass.h (from rev 141439, trunk/Source/WTF/wtf/TypeSafeEnum.h) (0 => 141499)


--- trunk/Source/WTF/wtf/EnumClass.h	                        (rev 0)
+++ trunk/Source/WTF/wtf/EnumClass.h	2013-01-31 23:49:26 UTC (rev 141499)
@@ -0,0 +1,124 @@
+/*
+ * Copyright (C) 2013 Apple Inc. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
+ * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
+ * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+ * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
+ * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
+ * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
+ */
+
+#ifndef WTF_EnumClass_h
+#define WTF_EnumClass_h
+
+#include <wtf/Compiler.h>
+
+namespace WTF {
+
+// How to define a type safe enum list using the ENUM_CLASS macros?
+// ===============================================================
+// To get an enum list like this:
+//
+//     enum class MyEnums {
+//         Value1,
+//         Value2,
+//         ...
+//         ValueN
+//     };
+//
+// ... write this:
+//
+//     ENUM_CLASS_BEGIN(MyEnums) {
+//         Value1,
+//         Value2,
+//         ...
+//         ValueN
+//     } ENUM_CLASS_END(MyEnums);
+//
+// The ENUM_CLASS macros will use C++11's enum class if the compiler supports it.
+// Otherwise, it will use the EnumClass template below.
+
+#if COMPILER_SUPPORTS(CXX_STRONG_ENUMS)
+#define ENUM_CLASS_BEGIN(__enumName) \
+    enum class __enumName
+
+#define ENUM_CLASS_END(__enumName)
+
+#else // !COMPILER_SUPPORTS(CXX_STRONG_ENUMS)
+
+// How to define a type safe enum list using the EnumClass template?
+// ================================================================
+// Definition should be a struct that encapsulates an enum list.
+// The enum list should be names Enums.
+//
+// Here's an example of how to define a type safe enum named MyEnum using
+// the EnumClass template:
+//
+//     struct MyEnumDefinition {
+//         enum Enums {
+//             ValueDefault,
+//             Value1,
+//             ...
+//             ValueN
+//         };
+//     };
+//     typedef EnumClass<MyEnumDefinition, MyEnumDefinition::ValueDefault> MyEnum;
+//
+// With that, you can now use MyEnum enum values as follow:
+//
+//     MyEnum value1; // value1 is assigned MyEnum::ValueDefault by default.
+//     MyEnum value2 = MyEnum::Value1; // value2 is assigned MyEnum::Value1;
+
+template <typename Definition>
+class EnumClass : public Definition {
+    typedef enum Definition::Enums Value;
+public:
+    ALWAYS_INLINE EnumClass() { }
+    ALWAYS_INLINE EnumClass(Value value) : m_value(value) { }
+
+    ALWAYS_INLINE Value value() const { return m_value; }
+
+    ALWAYS_INLINE bool operator==(const EnumClass other) { return m_value == other.m_value; }
+    ALWAYS_INLINE bool operator!=(const EnumClass other) { return m_value != other.m_value; }
+    ALWAYS_INLINE bool operator<(const EnumClass other) { return m_value < other.m_value; }
+    ALWAYS_INLINE bool operator<=(const EnumClass other) { return m_value <= other.m_value; }
+    ALWAYS_INLINE bool operator>(const EnumClass other) { return m_value > other.m_value; }
+    ALWAYS_INLINE bool operator>=(const EnumClass other) { return m_value >= other.m_value; }
+
+private:
+    Value m_value;
+};
+
+#define ENUM_CLASS_BEGIN(__enumName) \
+    struct __enumName ## Definition { \
+        enum Enums
+
+#define ENUM_CLASS_END(__enumName) \
+        ; \
+    }; \
+    typedef EnumClass< __enumName ## Definition > __enumName
+
+#endif // !COMPILER_SUPPORTS(CXX_STRONG_ENUMS)
+
+} // namespace WTF
+
+#if !COMPILER_SUPPORTS(CXX_STRONG_ENUMS)
+using WTF::EnumClass;
+#endif
+
+#endif // WTF_EnumClass_h

Deleted: trunk/Source/WTF/wtf/TypeSafeEnum.h (141498 => 141499)


--- trunk/Source/WTF/wtf/TypeSafeEnum.h	2013-01-31 23:46:03 UTC (rev 141498)
+++ trunk/Source/WTF/wtf/TypeSafeEnum.h	2013-01-31 23:49:26 UTC (rev 141499)
@@ -1,78 +0,0 @@
-/*
- * Copyright (C) 2013 Apple Inc. All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- *    notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- *    notice, this list of conditions and the following disclaimer in the
- *    documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
- * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
- * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
- * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
- * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
- * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
- * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
- * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
- */
-
-#ifndef WTF_TypeSafeEnum_h
-#define WTF_TypeSafeEnum_h
-
-namespace WTF {
-
-// How to define a type safe enum list using TypeSafeEnum?
-// ======================================================
-// Definition should be a struct that encapsulates an enum list.
-// The enum list should be names Enums.
-//
-// Here's an example of how to define a type safe enum named MyEnum using
-// the TypeSafeEnum template:
-//
-//     struct MyEnumDefinition {
-//         enum Enums {
-//             ValueDefault,
-//             Value1,
-//             ...
-//             ValueN
-//         };
-//     };
-//     typedef TypeSafeEnum<MyEnumDefinition, MyEnumDefinition::ValueDefault> MyEnum;
-//
-// With that, you can now use MyEnum enum values as follow:
-//
-//     MyEnum value1; // value1 is assigned MyEnum::ValueDefault by default.
-//     MyEnum value2 = MyEnum::Value1; // value2 is assigned MyEnum::Value1;
-
-template <typename Definition, typename Definition::Enums defaultValue>
-class TypeSafeEnum : public Definition {
-    typedef enum Definition::Enums Value;
-public:
-    ALWAYS_INLINE TypeSafeEnum() : m_value(defaultValue) { }
-    ALWAYS_INLINE TypeSafeEnum(Value value) : m_value(value) { }
-
-    ALWAYS_INLINE Value value() const { return m_value; }
-
-    ALWAYS_INLINE bool operator==(const TypeSafeEnum other) { return m_value == other.m_value; }
-    ALWAYS_INLINE bool operator!=(const TypeSafeEnum other) { return m_value != other.m_value; }
-    ALWAYS_INLINE bool operator<(const TypeSafeEnum other) { return m_value < other.m_value; }
-    ALWAYS_INLINE bool operator<=(const TypeSafeEnum other) { return m_value <= other.m_value; }
-    ALWAYS_INLINE bool operator>(const TypeSafeEnum other) { return m_value > other.m_value; }
-    ALWAYS_INLINE bool operator>=(const TypeSafeEnum other) { return m_value >= other.m_value; }
-
-private:
-    Value m_value;
-};
-
-} // namespace WTF
-
-using WTF::TypeSafeEnum;
-
-#endif // WTF_TypeSafeEnum_h

Modified: trunk/Source/WebCore/ChangeLog (141498 => 141499)


--- trunk/Source/WebCore/ChangeLog	2013-01-31 23:46:03 UTC (rev 141498)
+++ trunk/Source/WebCore/ChangeLog	2013-01-31 23:49:26 UTC (rev 141499)
@@ -1,3 +1,15 @@
+2013-01-31  Mark Lam  <[email protected]>
+
+        Abstraction for hiding enum class.
+        https://bugs.webkit.org/show_bug.cgi?id=108533
+
+        Reviewed by Anders Carlsson.
+
+        No new tests.
+
+        * Modules/webdatabase/DatabaseError.h:
+        (WebCore::ENUM_CLASS_BEGIN):
+
 2013-01-31  Arnaud Renevier  <[email protected]>
 
         [Gtk] drag and drop has black background without composition

Modified: trunk/Source/WebCore/Modules/webdatabase/DatabaseError.h (141498 => 141499)


--- trunk/Source/WebCore/Modules/webdatabase/DatabaseError.h	2013-01-31 23:46:03 UTC (rev 141498)
+++ trunk/Source/WebCore/Modules/webdatabase/DatabaseError.h	2013-01-31 23:49:26 UTC (rev 141499)
@@ -28,22 +28,18 @@
 
 #if ENABLE(SQL_DATABASE)
 
-#include <wtf/TypeSafeEnum.h>
+#include <wtf/EnumClass.h>
 
 namespace WebCore {
 
-struct DatabaseErrorDefinition {
-    enum Enums {
-        None = 0,
-        CannotOpenDatabase,
-        DatabaseIsBeingDeleted,
-        DatabaseSizeExceededQuota,
-        DatabaseSizeOverflowed
-    };
-};
+ENUM_CLASS_BEGIN(DatabaseError) {
+    None = 0,
+    CannotOpenDatabase,
+    DatabaseIsBeingDeleted,
+    DatabaseSizeExceededQuota,
+    DatabaseSizeOverflowed
+} ENUM_CLASS_END(DatabaseError);
 
-typedef TypeSafeEnum<DatabaseErrorDefinition, DatabaseErrorDefinition::None> DatabaseError;
-
 } // namespace WebCore
 
 #endif // ENABLE(SQL_DATABASE)
_______________________________________________
webkit-changes mailing list
[email protected]
https://lists.webkit.org/mailman/listinfo/webkit-changes

Reply via email to