http://llvm.org/bugs/show_bug.cgi?id=10248
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@134327 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/include/__bit_reference b/include/__bit_reference
index 57b92ea..d62bec7 100644
--- a/include/__bit_reference
+++ b/include/__bit_reference
@@ -21,7 +21,13 @@
template <class _C, bool _IsConst> class __bit_iterator;
template <class _C> class __bit_const_reference;
-template <class _C>
+template <class _Tp>
+struct __has_storage_type
+{
+ static const bool value = false;
+};
+
+template <class _C, bool = __has_storage_type<_C>::value>
class __bit_reference
{
typedef typename _C::__storage_type __storage_type;
@@ -66,6 +72,11 @@
: __seg_(__s), __mask_(__m) {}
};
+template <class _C>
+class __bit_reference<_C, false>
+{
+};
+
template <class _C, class _D>
_LIBCPP_INLINE_VISIBILITY inline
void
diff --git a/include/bitset b/include/bitset
index de0a201..f0e8027 100644
--- a/include/bitset
+++ b/include/bitset
@@ -130,6 +130,15 @@
_LIBCPP_BEGIN_NAMESPACE_STD
template <size_t _N_words, size_t _Size>
+class __bitset;
+
+template <size_t _N_words, size_t _Size>
+struct __has_storage_type<__bitset<_N_words, _Size> >
+{
+ static const bool value = true;
+};
+
+template <size_t _N_words, size_t _Size>
class __bitset
{
public:
diff --git a/include/vector b/include/vector
index 0bd82ea..d8c9feb 100644
--- a/include/vector
+++ b/include/vector
@@ -1749,6 +1749,12 @@
template <class _Allocator> struct hash<vector<bool, _Allocator> >;
template <class _Allocator>
+struct __has_storage_type<vector<bool, _Allocator> >
+{
+ static const bool value = true;
+};
+
+template <class _Allocator>
class _LIBCPP_VISIBLE vector<bool, _Allocator>
: private __vector_base_common<true>
{
@@ -1757,8 +1763,6 @@
typedef bool value_type;
typedef _Allocator allocator_type;
typedef allocator_traits<allocator_type> __alloc_traits;
- typedef __bit_reference<vector> reference;
- typedef __bit_const_reference<vector> const_reference;
typedef typename __alloc_traits::size_type size_type;
typedef typename __alloc_traits::difference_type difference_type;
typedef __bit_iterator<vector, false> pointer;
@@ -1798,6 +1802,9 @@
size_type __size_;
__compressed_pair<size_type, __storage_allocator> __cap_alloc_;
+ typedef __bit_reference<vector> reference;
+ typedef __bit_const_reference<vector> const_reference;
+
_LIBCPP_INLINE_VISIBILITY
size_type& __cap() _NOEXCEPT
{return __cap_alloc_.first();}