Add constructor to Optional<RefType> which accepts a RefType* in addition RefType& and nullptr. This is required since *nullptr is illegal and writing (ptr == nullptr) ? nullptr : *ptr isn't an efficient solution for the problem. (#45)

This commit is contained in:
Markus Tavenrath 2016-11-04 09:14:53 +01:00 committed by Andreas Süßenbach
parent 952667d3c0
commit 3e3c16a0a1
2 changed files with 40 additions and 37 deletions

View File

@ -187,23 +187,24 @@ const std::string flagsHeader(
"\n" "\n"
); );
std::string const optionalClassHeader = ( std::string const optionalClassHeader = R"(
" template <typename RefType>\n" template <typename RefType>
" class Optional\n" class Optional
" {\n" {
" public:\n" public:
" Optional(RefType & reference) { m_ptr = &reference; }\n" Optional(RefType & reference) { m_ptr = &reference; }
" Optional(std::nullptr_t) { m_ptr = nullptr; }\n" Optional(RefType * ptr) { m_ptr = ptr; }
"\n" Optional(std::nullptr_t) { m_ptr = nullptr; }
" operator RefType*() const { return m_ptr; }\n"
" RefType const* operator->() const { return m_ptr; }\n" operator RefType*() const { return m_ptr; }
" explicit operator bool() const { return !!m_ptr; }\n" RefType const* operator->() const { return m_ptr; }
"\n" explicit operator bool() const { return !!m_ptr; }
" private:\n"
" RefType *m_ptr;\n" private:
" };\n" RefType *m_ptr;
"\n" };
);
)";
std::string const arrayProxyHeader = ( std::string const arrayProxyHeader = (
"#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\n" "#ifndef VULKAN_HPP_DISABLE_ENHANCED_MODE\n"

View File

@ -208,11 +208,13 @@ namespace vk
return flags ^ bit; return flags ^ bit;
} }
template <typename RefType> template <typename RefType>
class Optional class Optional
{ {
public: public:
Optional(RefType & reference) { m_ptr = &reference; } Optional(RefType & reference) { m_ptr = &reference; }
Optional(RefType * ptr) { m_ptr = ptr; }
Optional(std::nullptr_t) { m_ptr = nullptr; } Optional(std::nullptr_t) { m_ptr = nullptr; }
operator RefType*() const { return m_ptr; } operator RefType*() const { return m_ptr; }