STL_MSFT created this revision.
STL_MSFT added reviewers: EricWF, mclow.lists.
STL_MSFT added a subscriber: cfe-commits.

Fix an MSVC x64 compiler error due to mismatched iterator types.

This was attempting to store a list<int, test_allocator<int>>::iterator in a 
list<int>::iterator. That isn't guaranteed by the Standard, and MSVC x64 
rejects it (even though our list iterators are SCARY) because test_allocator 
has 32-bit size_type/difference_type, and our iterators take that into account 
even as they erase the allocator type itself.

https://reviews.llvm.org/D22972

Files:
  test/std/containers/sequences/list/list.cons/initializer_list_alloc.pass.cpp

Index: 
test/std/containers/sequences/list/list.cons/initializer_list_alloc.pass.cpp
===================================================================
--- test/std/containers/sequences/list/list.cons/initializer_list_alloc.pass.cpp
+++ test/std/containers/sequences/list/list.cons/initializer_list_alloc.pass.cpp
@@ -24,7 +24,7 @@
     std::list<int, test_allocator<int>> d({3, 4, 5, 6}, 
test_allocator<int>(3));
     assert(d.get_allocator() == test_allocator<int>(3));
     assert(d.size() == 4);
-    std::list<int>::iterator i = d.begin();
+    std::list<int, test_allocator<int>>::iterator i = d.begin();
     assert(*i++ == 3);
     assert(*i++ == 4);
     assert(*i++ == 5);


Index: test/std/containers/sequences/list/list.cons/initializer_list_alloc.pass.cpp
===================================================================
--- test/std/containers/sequences/list/list.cons/initializer_list_alloc.pass.cpp
+++ test/std/containers/sequences/list/list.cons/initializer_list_alloc.pass.cpp
@@ -24,7 +24,7 @@
     std::list<int, test_allocator<int>> d({3, 4, 5, 6}, test_allocator<int>(3));
     assert(d.get_allocator() == test_allocator<int>(3));
     assert(d.size() == 4);
-    std::list<int>::iterator i = d.begin();
+    std::list<int, test_allocator<int>>::iterator i = d.begin();
     assert(*i++ == 3);
     assert(*i++ == 4);
     assert(*i++ == 5);
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to