Commit cfd26881 authored by Kenton Varda's avatar Kenton Varda

Fix ParserRef null constexpr vtable crash in MSVC.

parent 2e7ece6b
...@@ -162,7 +162,13 @@ private: ...@@ -162,7 +162,13 @@ private:
}; };
template <typename ParserImpl> template <typename ParserImpl>
struct WrapperImplInstance { struct WrapperImplInstance {
#if _MSC_VER
// TODO(msvc): MSVC currently fails to initialize vtable pointers for constexpr values so
// we have to make this just const instead.
static const WrapperImpl<ParserImpl> instance;
#else
static constexpr WrapperImpl<ParserImpl> instance = WrapperImpl<ParserImpl>(); static constexpr WrapperImpl<ParserImpl> instance = WrapperImpl<ParserImpl>();
#endif
}; };
const void* parser; const void* parser;
...@@ -171,8 +177,13 @@ private: ...@@ -171,8 +177,13 @@ private:
template <typename Input, typename Output> template <typename Input, typename Output>
template <typename ParserImpl> template <typename ParserImpl>
#if _MSC_VER
const typename ParserRef<Input, Output>::template WrapperImpl<ParserImpl>
ParserRef<Input, Output>::WrapperImplInstance<ParserImpl>::instance = WrapperImpl<ParserImpl>();
#else
constexpr typename ParserRef<Input, Output>::template WrapperImpl<ParserImpl> constexpr typename ParserRef<Input, Output>::template WrapperImpl<ParserImpl>
ParserRef<Input, Output>::WrapperImplInstance<ParserImpl>::instance; ParserRef<Input, Output>::WrapperImplInstance<ParserImpl>::instance;
#endif
template <typename Input, typename ParserImpl> template <typename Input, typename ParserImpl>
constexpr ParserRef<Input, OutputType<ParserImpl, Input>> ref(ParserImpl& impl) { constexpr ParserRef<Input, OutputType<ParserImpl, Input>> ref(ParserImpl& impl) {
......
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