On 11/01/17 10:29 +0000, Jonathan Wakely wrote:
On 11/01/17 00:19 +0200, Ville Voutilainen wrote:@@ -1086,7 +1099,12 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION { return !this->_M_valid(); }constexpr size_t index() const noexcept - { return this->_M_index; } + { + if (this->_M_index == + typename _Base::_Storage::__index_type(variant_npos)) + return variant_npos; + return this->_M_index;GCC doesn't seem to be smart enough to optimize the branch away here.
But that's only for 32-bit x86. It optimizes well for x86_64, so no need to obfuscate it.
