Commit d7ddd58d authored by Harris Hancock's avatar Harris Hancock

KJ_SWITCH_ONEOF should parenthesize its argument

This allows us to deal with Maybe<OneOf<...>> variables properly inside a KJ_IF_MAYBE block.
parent ac10f36b
...@@ -151,4 +151,23 @@ TEST(OneOf, Switch) { ...@@ -151,4 +151,23 @@ TEST(OneOf, Switch) {
} }
} }
TEST(OneOf, Maybe) {
Maybe<OneOf<int, float>> var;
var = OneOf<int, float>(123);
KJ_IF_MAYBE(v, var) {
// At one time this failed to compile. Note that a Maybe<OneOf<...>> isn't necessarily great
// style -- you might be better off with an explicit OneOf<Empty, ...>. Nevertheless, it should
// compile.
KJ_SWITCH_ONEOF(*v) {
KJ_CASE_ONEOF(i, int) {
KJ_EXPECT(i == 123);
}
KJ_CASE_ONEOF(n, float) {
KJ_FAIL_ASSERT("expected int, got float", n);
}
}
}
}
} // namespace kj } // namespace kj
...@@ -238,11 +238,11 @@ void OneOf<Variants...>::allHandled() { ...@@ -238,11 +238,11 @@ void OneOf<Variants...>::allHandled() {
#if __cplusplus > 201402L #if __cplusplus > 201402L
#define KJ_SWITCH_ONEOF(value) \ #define KJ_SWITCH_ONEOF(value) \
switch (auto _kj_switch_subject = value._switchSubject(); _kj_switch_subject->which()) switch (auto _kj_switch_subject = (value)._switchSubject(); _kj_switch_subject->which())
#else #else
#define KJ_SWITCH_ONEOF(value) \ #define KJ_SWITCH_ONEOF(value) \
/* Without C++17, we can only support one switch per containing block. Deal with it. */ \ /* Without C++17, we can only support one switch per containing block. Deal with it. */ \
auto _kj_switch_subject = value._switchSubject(); \ auto _kj_switch_subject = (value)._switchSubject(); \
switch (_kj_switch_subject->which()) switch (_kj_switch_subject->which())
#endif #endif
#define KJ_CASE_ONEOF(name, ...) \ #define KJ_CASE_ONEOF(name, ...) \
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment