Title: [199107] trunk
Revision
199107
Author
[email protected]
Date
2016-04-06 11:39:59 -0700 (Wed, 06 Apr 2016)

Log Message

Implement operator== and operator!= for Optional<>
https://bugs.webkit.org/show_bug.cgi?id=156266

Reviewed by Anders Carlsson.
Source/WTF:

Implement non-member operator== and operator!= variants for Optional<>.

* wtf/Optional.h:
(WTF::operator==):
(WTF::operator!=):

Tools:

* TestWebKitAPI/Tests/WTF/Optional.cpp:
(TestWebKitAPI::TEST):

Modified Paths

Diff

Modified: trunk/Source/WTF/ChangeLog (199106 => 199107)


--- trunk/Source/WTF/ChangeLog	2016-04-06 18:26:11 UTC (rev 199106)
+++ trunk/Source/WTF/ChangeLog	2016-04-06 18:39:59 UTC (rev 199107)
@@ -1,3 +1,16 @@
+2016-04-05  Simon Fraser  <[email protected]>
+
+        Implement operator== and operator!= for Optional<>
+        https://bugs.webkit.org/show_bug.cgi?id=156266
+
+        Reviewed by Anders Carlsson.
+        
+        Implement non-member operator== and operator!= variants for Optional<>.
+
+        * wtf/Optional.h:
+        (WTF::operator==):
+        (WTF::operator!=):
+
 2016-03-19  Filip Pizlo  <[email protected]>
 
         DFG and FTL should constant-fold RegExpExec

Modified: trunk/Source/WTF/wtf/Optional.h (199106 => 199107)


--- trunk/Source/WTF/wtf/Optional.h	2016-04-06 18:26:11 UTC (rev 199106)
+++ trunk/Source/WTF/wtf/Optional.h	2016-04-06 18:39:59 UTC (rev 199107)
@@ -197,6 +197,66 @@
 };
 
 template<typename T>
+constexpr bool operator==(const Optional<T>& lhs, const Optional<T>& rhs)
+{
+    return static_cast<bool>(lhs) == static_cast<bool>(rhs) && (!static_cast<bool>(lhs) || lhs.value() == rhs.value());
+}
+
+template<typename T>
+constexpr bool operator!=(const Optional<T>& lhs, const Optional<T>& rhs)
+{
+    return !(lhs == rhs);
+}
+
+template<typename T>
+constexpr bool operator==(const Optional<T>& opt, NulloptTag)
+{
+    return !opt;
+}
+
+template<typename T>
+constexpr bool operator!=(const Optional<T>& opt, NulloptTag)
+{
+    return static_cast<bool>(opt);
+}
+
+template<typename T>
+constexpr bool operator==(NulloptTag, const Optional<T>& opt)
+{
+    return !opt;
+}
+
+template<typename T>
+constexpr bool operator!=(NulloptTag, const Optional<T>& opt)
+{
+    return static_cast<bool>(opt);
+}
+
+template<typename T>
+constexpr bool operator==(const Optional<T>& opt, const T& value)
+{
+    return opt && opt.value() == value;
+}
+
+template<typename T>
+constexpr bool operator!=(const Optional<T>& opt, const T& value)
+{
+    return !(opt == value);
+}
+
+template<typename T>
+constexpr bool operator==(const T& value, const Optional<T>& opt)
+{
+    return opt && opt.value() == value;
+}
+
+template<typename T>
+constexpr bool operator!=(const T& value, const Optional<T>& opt)
+{
+    return !(value == opt);
+}
+
+template<typename T>
 Optional<typename std::decay<T>::type>
 makeOptional(T&& value)
 {

Modified: trunk/Tools/ChangeLog (199106 => 199107)


--- trunk/Tools/ChangeLog	2016-04-06 18:26:11 UTC (rev 199106)
+++ trunk/Tools/ChangeLog	2016-04-06 18:39:59 UTC (rev 199107)
@@ -1,3 +1,13 @@
+2016-04-05  Simon Fraser  <[email protected]>
+
+        Implement operator== and operator!= for Optional<>
+        https://bugs.webkit.org/show_bug.cgi?id=156266
+
+        Reviewed by Anders Carlsson.
+
+        * TestWebKitAPI/Tests/WTF/Optional.cpp:
+        (TestWebKitAPI::TEST):
+
 2016-04-05  Alex Christensen  <[email protected]>
 
         Make CMake-generated binaries on Mac able to run

Modified: trunk/Tools/TestWebKitAPI/Tests/WTF/Optional.cpp (199106 => 199107)


--- trunk/Tools/TestWebKitAPI/Tests/WTF/Optional.cpp	2016-04-06 18:26:11 UTC (rev 199106)
+++ trunk/Tools/TestWebKitAPI/Tests/WTF/Optional.cpp	2016-04-06 18:39:59 UTC (rev 199107)
@@ -93,4 +93,58 @@
     EXPECT_EQ(result, 250);
 }
 
+TEST(WTF_Optional, Equality)
+{
+    Optional<int> unengaged1;
+    Optional<int> unengaged2;
+
+    Optional<int> engaged1 { 1 };
+    Optional<int> engaged2 { 2 };
+    Optional<int> engagedx2 { 2 };
+
+    EXPECT_TRUE(unengaged1 == unengaged2);
+    EXPECT_FALSE(engaged1 == engaged2);
+    EXPECT_FALSE(engaged1 == unengaged1);
+    EXPECT_TRUE(engaged2 == engagedx2);
+
+    EXPECT_TRUE(unengaged1 == Nullopt);
+    EXPECT_FALSE(engaged1 == Nullopt);
+    EXPECT_TRUE(Nullopt == unengaged1);
+    EXPECT_FALSE(Nullopt == engaged1);
+
+    EXPECT_TRUE(engaged1 == 1);
+    EXPECT_TRUE(1 == engaged1);
+    EXPECT_FALSE(unengaged1 == 1);
+    EXPECT_FALSE(1 == unengaged1);
+}
+
+TEST(WTF_Optional, Inequality)
+{
+    Optional<int> unengaged1;
+    Optional<int> unengaged2;
+
+    Optional<int> engaged1 { 1 };
+    Optional<int> engaged2 { 2 };
+    Optional<int> engagedx2 { 2 };
+
+    EXPECT_FALSE(unengaged1 != unengaged2);
+    EXPECT_TRUE(engaged1 != engaged2);
+    EXPECT_TRUE(engaged1 != unengaged1);
+    EXPECT_FALSE(engaged2 != engagedx2);
+
+    EXPECT_FALSE(unengaged1 != Nullopt);
+    EXPECT_TRUE(engaged1 != Nullopt);
+    EXPECT_FALSE(Nullopt != unengaged1);
+    EXPECT_TRUE(Nullopt != engaged1);
+
+    EXPECT_FALSE(engaged1 != 1);
+    EXPECT_TRUE(engaged1 != 2);
+    EXPECT_FALSE(1 != engaged1);
+    EXPECT_TRUE(2 != engaged1);
+
+    EXPECT_TRUE(unengaged1 != 1);
+    EXPECT_TRUE(1 != unengaged1);
+}
+
+
 } // namespace TestWebKitAPI
_______________________________________________
webkit-changes mailing list
[email protected]
https://lists.webkit.org/mailman/listinfo/webkit-changes

Reply via email to