On Mon, 18 Aug 2025 at 15:40, Jonathan Wakely <jwak...@redhat.com> wrote:
>
> On Thu, 24 Jul 2025 at 08:33, Tomasz Kamiński <tkami...@redhat.com> wrote:
> >
> > Removed the wrong_stuff() function, which was effectively empty for
> > actual test runs. Replaced the manual failure counter with the VERIFY
> > macro to simplify identifying failures.
> >
> >         PR libstdc++/104874
> >
> > libstdc++-v3/ChangeLog:
> >
> >         * testsuite/24_iterators/random_access/string_vector_iterators.cc:
> >         Reworked.
> > ---
> >  .../random_access/string_vector_iterators.cc  | 525 +++++-------------
> >  1 file changed, 146 insertions(+), 379 deletions(-)
> >
> > diff --git 
> > a/libstdc++-v3/testsuite/24_iterators/random_access/string_vector_iterators.cc
> >  
> > b/libstdc++-v3/testsuite/24_iterators/random_access/string_vector_iterators.cc
> > index a8dbe5180aa..3c01762f36f 100644
> > --- 
> > a/libstdc++-v3/testsuite/24_iterators/random_access/string_vector_iterators.cc
> > +++ 
> > b/libstdc++-v3/testsuite/24_iterators/random_access/string_vector_iterators.cc
> > @@ -17,238 +17,162 @@
> >  // along with this program; see the file COPYING3.  If not see
> >  // <http://www.gnu.org/licenses/>.
> >
> > -
> >  #include <string>
> >  #include <vector>
> >  #include <testsuite_hooks.h>
> >
> > -int
> > +void
> >  string_stuff()
> >  {
> > -   int failures(0);
> > -
> >     std::string s("abcde");
> >
> >     std::string::iterator i1(s.begin());
> > -   if (*i1 != 'a')
> > -      ++failures;
> > +   VERIFY( *i1 == 'a' );
> >
> >     ++i1;
> > -   if (*i1 != 'b')
> > -      ++failures;
> > +   VERIFY( *i1 == 'b' );
> >
> > -   if (*i1++ != 'b')
> > -       ++failures;
> > -   if (*i1 != 'c')
> > -      ++failures;
> > +   VERIFY( *i1++ == 'b' );
> > +   VERIFY( *i1 == 'c' );
> >
> >     ++ ++i1;
> > -   if (*i1 != 'e')
> > -      ++failures;
> > +   VERIFY( *i1 == 'e' );
> >
> >     --i1;
> > -   if (*i1 != 'd')
> > -      ++failures;
> > +   VERIFY( *i1 == 'd' );
> >
> > -   if (*i1-- != 'd')
> > -      ++failures;
> > -   if (*i1 != 'c')
> > -      ++failures;
> > +   VERIFY( *i1-- == 'd' );
> > +   VERIFY( *i1 == 'c' );
> >
> >     -- --i1;
> > -   if (*i1 != 'a')
> > -      ++failures;
> > +   VERIFY( *i1 == 'a' );
> >
> >     std::string::iterator i2;
> >     i2 = s.end();
> >     std::iterator_traits<std::string::iterator>::difference_type d1;
> >     d1 = i2 - i1;
> > -   if (d1 != 5)
> > -      ++failures;
> > +   VERIFY( d1 == 5 );
> >
> >     std::iterator_traits<std::string::iterator>::value_type v1;
> >     v1 = i1[0];
> > -   if (v1 != 'a')
> > -      ++failures;
> > +   VERIFY( v1 == 'a' );
> >
> >     std::iterator_traits<std::string::iterator>::reference r1(i1[0]);
> > -   if (r1 != 'a')
> > -      ++failures;
> > +   VERIFY( r1 == 'a' );
> >     r1 = 'x';
> > -   if (r1 != 'x')
> > -      ++failures;
> > +   VERIFY( r1 == 'x' );
> >     r1 = 'a';
> >
> > -   if ((i1 != i2) != true)
> > -      ++failures;
> > -   if ((i1 == i2) != false)
> > -      ++failures;
> > -   if ((i1 <  i2) != true)
> > -      ++failures;
> > -   if ((i1 >  i2) != false)
> > -      ++failures;
> > -   if ((i1 <= i2) != true)
> > -      ++failures;
> > -   if ((i1 >= i2) != false)
> > -      ++failures;
> > +   VERIFY( (i1 != i2) == true );
> > +   VERIFY( (i1 == i2) == false );
> > +   VERIFY( (i1 <  i2) == true );
> > +   VERIFY( (i1 >  i2) == false );
> > +   VERIFY( (i1 <= i2) == true );
> > +   VERIFY( (i1 >= i2) == false );
> >
> >     std::string::iterator i3;
> >     i3 = i1;
> > -   if ((i3 == i1) != true)
> > -      ++failures;
> > +   VERIFY( (i3 == i1) == true );
> >
> >     i3 += 5;
> > -   if ((i3 == i2) != true)
> > -      ++failures;
> > +   VERIFY( (i3 == i2) == true );
> >
> >     i3 -= 5;
> > -   if ((i3 == i1) != true)
> > -      ++failures;
> > -
> > -   if (i3 + 5 != i2)
> > -      ++failures;
> > -
> > -   if (5 + i3 != i2)
> > -      ++failures;
> > +   VERIFY( (i3 == i1) == true );
> >
> > -   if (i2 - 5 != i3)
> > -      ++failures;
> > +   VERIFY( i3 + 5 == i2 );
> > +   VERIFY( 5 + i3 == i2 );
> > +   VERIFY( i2 - 5 == i3 );
> >
> > -   if (i1[0] != 'a')
> > -      ++failures;
> > +   VERIFY( i1[0] == 'a' );
> >
> >     i1[4] = 'x';
> > -   if (i2[-1] != 'x')
> > -      ++failures;
> > +   VERIFY( i2[-1] == 'x' );
> >     i1[4] = 'e';
> >
> >     i1[2] = 'x';
> > -   if (i2[-3] != 'x')
> > -      ++failures;
> > +   VERIFY( i2[-3] == 'x' );
> >     i1[2] = 'c';
> >
> >     std::string::const_iterator ci1(s.begin());
> > -   if (*ci1 != 'a')
> > -      ++failures;
> > +   VERIFY( *ci1 == 'a' );
> >
> >     ++ci1;
> > -   if (*ci1 != 'b')
> > -      ++failures;
> > +   VERIFY( *ci1 == 'b' );
> >
> > -   if (*ci1++ != 'b')
> > -      ++failures;
> > -   if (*ci1 != 'c')
> > -      ++failures;
> > +   VERIFY( *ci1++ == 'b' );
> > +   VERIFY( *ci1 == 'c' );
> >
> >     ++ ++ci1;
> > -   if (*ci1 != 'e')
> > -      ++failures;
> > +   VERIFY( *ci1 == 'e' );
> >
> >     --ci1;
> > -   if (*ci1 != 'd')
> > -      ++failures;
> > +   VERIFY( *ci1 == 'd' );
> >
> > -   if (*ci1-- != 'd')
> > -      ++failures;
> > -   if (*ci1 != 'c')
> > -      ++failures;
> > +   VERIFY( *ci1-- == 'd' );
> > +   VERIFY( *ci1 == 'c' );
> >
> >     -- --ci1;
> > -   if (*ci1 != 'a')
> > -      ++failures;
> > +   VERIFY( *ci1 == 'a' );
> >
> >     std::string::const_iterator ci2;
> >     ci2 = s.end();
> >     std::iterator_traits<std::string::const_iterator>::difference_type d2;
> >     d2 = ci2 - ci1;
> > -   if (d2 != 5)
> > -     ++failures;
> > +   VERIFY( d2 == 5 );
> >
> >     std::iterator_traits<std::string::const_iterator>::value_type v2;
> >     v2 = ci1[0];
> > -   if (v2 != 'a')
> > -     ++failures;
> > +   VERIFY( v2 == 'a' );
> >
> >     std::iterator_traits<std::string::const_iterator>::reference r2(ci1[0]);
> > -   if (r2 != 'a')
> > -      ++failures;
> > -
> > -   if ((ci1 != ci2) != true)
> > -      ++failures;
> > -   if ((ci1 == ci2) != false)
> > -      ++failures;
> > -   if ((ci1 <  ci2) != true)
> > -      ++failures;
> > -   if ((ci1 >  ci2) != false)
> > -      ++failures;
> > -   if ((ci1 <= ci2) != true)
> > -      ++failures;
> > -   if ((ci1 >= ci2) != false)
> > -      ++failures;
> > +   VERIFY( r2 == 'a' );
> > +
> > +   VERIFY( (ci1 != ci2) == true );
> > +   VERIFY( (ci1 == ci2) == false );
> > +   VERIFY( (ci1 <  ci2) == true );
> > +   VERIFY( (ci1 >  ci2) == false );
> > +   VERIFY( (ci1 <= ci2) == true );
> > +   VERIFY( (ci1 >= ci2) == false );
> >
> >     std::string::const_iterator ci3;
> >     ci3 = ci1;
> > -   if ((ci3 == ci1) != true)
> > -      ++failures;
> > +   VERIFY( ci3 == ci1 );
> >
> >     ci3 += 5;
> > -   if ((ci3 == ci2) != true)
> > -      ++failures;
> > +   VERIFY( ci3 == ci2 );
> >
> >     ci3 -= 5;
> > -   if ((ci3 == ci1) != true)
> > -      ++failures;
> > -
> > -   if (ci3 + 5 != ci2)
> > -      ++failures;
> > -
> > -   if (5 + ci3 != ci2)
> > -      ++failures;
> > -
> > -   if (ci2 - 5 != ci3)
> > -      ++failures;
> > +   VERIFY( ci3 == ci1 );
> >
> > -   if (ci1[2] != 'c')
> > -      ++failures;
> > +   VERIFY( ci3 + 5 == ci2 );
> > +   VERIFY( 5 + ci3 == ci2 );
> > +   VERIFY( ci2 - 5 == ci3 );
> >
> > -   if (ci2[-1] != 'e')
> > -      ++failures;
> > +   VERIFY( ci1[2] == 'c' );
> > +   VERIFY( ci2[-1] == 'e' );
> >
> >     // iterator and const_iterator
> >     std::string::const_iterator ci4(i1);
> > -   if ((ci4 == i1) != true)
> > -      ++failures;
> > -   if ((ci4 != i1) != false)
> > -      ++failures;
> > -   if ((ci4 < i1)  != false)
> > -     ++failures;
> > -   if ((ci4 > i1)  != false)
> > -     ++failures;
> > -   if ((ci4 <= i1) != true)
> > -     ++failures;
> > -   if ((ci4 >= i1) != true)
> > -     ++failures;
> > +   VERIFY( (ci4 == i1) == true );
> > +   VERIFY( (ci4 != i1) == false );
> > +   VERIFY( (ci4 < i1) == false );
> > +   VERIFY( (ci4 > i1) == false );
> > +   VERIFY( (ci4 <= i1) == true );
> > +   VERIFY( (ci4 >= i1) == true );
> >     ci4 = i2;
> > -   if ((i2 == ci4) != true)
> > -     ++failures;
> > -   if ((i2 < ci4)  != false)
> > -     ++failures;
> > -   if ((i2 > ci4)  != false)
> > -     ++failures;
> > -   if ((i2 <= ci4) != true)
> > -     ++failures;
> > -   if ((i2 >= ci4) != true)
> > -     ++failures;
> > +   VERIFY( (i2 == ci4) == true );
> > +   VERIFY( (i2 < ci4) == false );
> > +   VERIFY( (i2 > ci4) == false );
> > +   VERIFY( (i2 <= ci4) == true );
> > +   VERIFY( (i2 >= ci4) == true );
> >
> >     const std::string cs("ABCDE");
> >     std::string::const_iterator ci5(cs.begin());
> > -   if (ci5[0] != 'A')
> > -      ++failures;
> > -
> > -   return failures;
> > +   VERIFY( ci5[0] == 'A' );
> >  }
> >
> > -int
> > +void
> >  vector_stuff()
> >  {
> >     int failures(0);
> > @@ -261,347 +185,190 @@ vector_stuff()
> >     v.push_back(int(5));
> >
> >     std::vector<int>::iterator i1(v.begin());
> > -   if (*i1 != 1)
> > -      ++failures;
> > +   VERIFY( *i1 == 1 );
> >
> >     ++i1;
> > -   if (*i1 != 2)
> > -      ++failures;
> > +   VERIFY( *i1 == 2 );
> >
> > -   if (*i1++ != 2)
> > -      ++failures;
> > -   if (*i1 != 3)
> > -      ++failures;
> > +   VERIFY( *i1++ == 2 );
> > +   VERIFY( *i1 == 3 );
> >
> >     ++ ++i1;
> > -   if (*i1 != 5)
> > -      ++failures;
> > +   VERIFY( *i1 == 5 );
> >
> >     --i1;
> > -   if (*i1 != 4)
> > -      ++failures;
> > +   VERIFY( *i1 == 4 );
> >
> > -   if (*i1-- != 4)
> > -      ++failures;
> > -   if (*i1 != 3)
> > -      ++failures;
> > +   VERIFY( *i1-- == 4 );
> > +   VERIFY( *i1 == 3 );
> >
> >     -- --i1;
> > -   if (*i1 != 1)
> > -      ++failures;
> > +   VERIFY( *i1 == 1 );
> >
> >     std::vector<int>::iterator i2;
> >     i2 = v.end();
> >     std::iterator_traits<std::vector<int>::iterator>::difference_type d1;
> >     d1 = i2 - i1;
> > -   if (d1 != 5)
> > -      ++failures;
> > +   VERIFY( d1 == 5 );
> >
> >     std::iterator_traits<std::vector<int>::iterator>::value_type v1;
> >     v1 = i1[0];
> > -   if (v1 != 1)
> > -      ++failures;
> > +   VERIFY( v1 == 1 );
> >
> >     std::iterator_traits<std::vector<int>::iterator>::reference r1(i1[0]);
> > -   if (r1 != 1)
> > -      ++failures;
> > +   VERIFY( r1 == 1 );
> >     r1 = 9;
> > -   if (r1 != 9)
> > -      ++failures;
> > +   VERIFY( r1 == 9 );
> >     r1 = 1;
> >
> > -   if ((i1 != i2) != true)
> > -      ++failures;
> > -   if ((i1 == i2) != false)
> > -      ++failures;
> > -   if ((i1 <  i2) != true)
> > -      ++failures;
> > -   if ((i1 >  i2) != false)
> > -      ++failures;
> > -   if ((i1 <= i2) != true)
> > -      ++failures;
> > -   if ((i1 >= i2) != false)
> > -      ++failures;
> > +   VERIFY( (i1 != i2) == true );
> > +   VERIFY( (i1 == i2) == false );
> > +   VERIFY( (i1 <  i2) == true );
> > +   VERIFY( (i1 >  i2) == false );
> > +   VERIFY( (i1 <= i2) == true );
> > +   VERIFY( (i1 >= i2) == false );
> >
> >     std::vector<int>::iterator i3;
> >     i3 = i1;
> > -   if ((i3 == i1) != true)
> > -      ++failures;
> > +   VERIFY( (i3 == i1) == true );
> >
> >     i3 += 5;
> > -   if ((i3 == i2) != true)
> > -      ++failures;
> > +   VERIFY( (i3 == i2) == true );
> >
> >     i3 -= 5;
> > -   if ((i3 == i1) != true)
> > -      ++failures;
> > -
> > -   if (i3 + 5 != i2)
> > -      ++failures;
> > -
> > -   if (5 + i3 != i2)
> > -      ++failures;
> > +   VERIFY( (i3 == i1) == true );
> >
> > -   if (i2 - 5 != i3)
> > -      ++failures;
> > +   VERIFY( i3 + 5 == i2 );
> > +   VERIFY( 5 + i3 == i2 );
> > +   VERIFY( i2 - 5 == i3 );
> >
> > -   if (i1[0] != 1)
> > -      ++failures;
> > +   VERIFY( i1[0] == 1 );
> >
> >     i1[4] = 9;
> > -   if (i2[-1] != 9)
> > -      ++failures;
> > +   VERIFY( i2[-1] == 9 );
> >     i1[4] = 5;
> >
> >     i1[2] = 9;
> > -   if (i2[-3] != 9)
> > -      ++failures;
> > +   VERIFY( i2[-3] == 9 );
> >     i1[2] = 3;
> >
> >     std::vector<int>::const_iterator ci1(v.begin());
> > -   if (*ci1 != 1)
> > -      ++failures;
> > +   VERIFY( *ci1 == 1 );
> >
> >     ++ci1;
> > -   if (*ci1 != 2)
> > -      ++failures;
> > +   VERIFY( *ci1 == 2 );
> >
> > -   if (*ci1++ != 2)
> > -      ++failures;
> > -   if (*ci1 != 3)
> > -      ++failures;
> > +   VERIFY( *ci1++ == 2 );
> > +   VERIFY( *ci1 == 3 );
> >
> >     ++ ++ci1;
> > -   if (*ci1 != 5)
> > -      ++failures;
> > +   VERIFY( *ci1 == 5 );
> >
> >     --ci1;
> > -   if (*ci1 != 4)
> > -      ++failures;
> > +   VERIFY( *ci1 == 4 );
> >
> > -   if (*ci1-- != 4)
> > -      ++failures;
> > -   if (*ci1 != 3)
> > -      ++failures;
> > +   VERIFY( *ci1-- == 4 );
> > +   VERIFY( *ci1 == 3 );
> >
> >     -- --ci1;
> > -   if (*ci1 != 1)
> > -      ++failures;
> > +   VERIFY( *ci1 == 1 );
> >
> >     std::vector<int>::const_iterator ci2;
> >     ci2 = v.end();
> >     std::iterator_traits<std::vector<int>::const_iterator>::difference_type 
> > d2;
> >     d2 = ci2 - ci1;
> > -   if (d2 != 5)
> > -      ++failures;
> > +   VERIFY( d2 == 5 );
> >
> >     std::iterator_traits<std::vector<int>::const_iterator>::value_type v2;
> >     v2 = ci1[0];
> > -   if (v2 != 1)
> > -      ++failures;
> > +   VERIFY( v2 == 1 );
> >
> >     std::iterator_traits<std::vector<int>::const_iterator>::reference
> >        r2(ci1[0]);
> > -   if (r2 != 1)
> > -      ++failures;
> > -
> > -   if ((ci1 != ci2) != true)
> > -      ++failures;
> > -   if ((ci1 == ci2) != false)
> > -      ++failures;
> > -   if ((ci1 <  ci2) != true)
> > -      ++failures;
> > -   if ((ci1 >  ci2) != false)
> > -      ++failures;
> > -   if ((ci1 <= ci2) != true)
> > -      ++failures;
> > -   if ((ci1 >= ci2) != false)
> > -      ++failures;
> > +   VERIFY( r2 == 1 );
> > +
> > +   VERIFY( (ci1 != ci2) == true );
> > +   VERIFY( (ci1 == ci2) == false );
> > +   VERIFY( (ci1 <  ci2) == true );
> > +   VERIFY( (ci1 >  ci2) == false );
> > +   VERIFY( (ci1 <= ci2) == true );
> > +   VERIFY( (ci1 >= ci2) == false );
> >
> >     std::vector<int>::const_iterator ci3;
> >     ci3 = ci1;
> > -   if ((ci3 == ci1) != true)
> > -      ++failures;
> > +   VERIFY( (ci3 == ci1) == true );
> >
> >     ci3 += 5;
> > -   if ((ci3 == ci2) != true)
> > -      ++failures;
> > +   VERIFY( (ci3 == ci2) == true );
> >
> >     ci3 -= 5;
> > -   if ((ci3 == ci1) != true)
> > -      ++failures;
> > -
> > -   if (ci3 + 5 != ci2)
> > -      ++failures;
> > +   VERIFY( (ci3 == ci1) == true );
> >
> > -   if (5 + ci3 != ci2)
> > -      ++failures;
> > +   VERIFY( ci3 + 5 == ci2 );
> > +   VERIFY( 5 + ci3 == ci2 );
> > +   VERIFY( ci2 - 5 == ci3 );
> >
> > -   if (ci2 - 5 != ci3)
> > -      ++failures;
> > +   VERIFY( ci1[2] == 3 );
> >
> > -   if (ci1[2] != 3)
> > -      ++failures;
> > -
> > -   if (ci2[-1] != 5)
> > -      ++failures;
> > +   VERIFY( ci2[-1] == 5 );
> >
> >     // iterator to const_iterator
> >     std::vector<int>::const_iterator ci4(i1);
> > -   if ((ci4 == i1) != true)
> > -      ++failures;
> > -   if ((ci4 != i1) != false)
> > -      ++failures;
> > -   if ((ci4 < i1)  != false)
> > -     ++failures;
> > -   if ((ci4 > i1)  != false)
> > -     ++failures;
> > -   if ((ci4 <= i1) != true)
> > -     ++failures;
> > -   if ((ci4 >= i1) != true)
> > -     ++failures;
> > +   VERIFY( (ci4 == i1) == true );
> > +   VERIFY( (ci4 != i1) == false );
> > +   VERIFY( (ci4 < i1) == false );
> > +   VERIFY( (ci4 > i1) == false );
> > +   VERIFY( (ci4 <= i1) == true );
> > +   VERIFY( (ci4 >= i1) == true );
> >     ci4 = i2;
> > -   if ((i2 == ci4) != true)
> > -     ++failures;
> > -   if ((i2 < ci4)  != false)
> > -     ++failures;
> > -   if ((i2 > ci4)  != false)
> > -     ++failures;
> > -   if ((i2 <= ci4) != true)
> > -     ++failures;
> > -   if ((i2 >= ci4) != true)
> > -     ++failures;
> > +   VERIFY( (i2 == ci4) == true );
> > +   VERIFY( (i2 < ci4) == false );
> > +   VERIFY( (i2 > ci4) == false );
> > +   VERIFY( (i2 <= ci4) == true );
> > +   VERIFY( (i2 >= ci4) == true );
> >
> >     const std::vector<int> cv(v);
> >     std::vector<int>::const_iterator ci5(cv.begin());
> > -   if (ci5[0] != 1)
> > -      ++failures;
> > +   VERIFY( ci5[0] == 1 );
> >
> >     std::vector<std::string> vs;
> >     vs.push_back(std::string("abc"));
> >     std::vector<std::string>::iterator ivs(vs.begin());
> > -   if (ivs->c_str()[1] != 'b')
> > -      ++failures;
> > -
> > -   return failures;
> > +   VERIFY( ivs->c_str()[1] == 'b' );
> >  }
> >
> > -int
> > +void
> >  reverse_stuff()
> >  {
> > -   int failures(0);
> > -
> >     std::string s("abcde");
> >
> >     std::string::reverse_iterator ri(s.rbegin());
> > -   if (*ri != 'e')
> > -      ++failures;
> > +   VERIFY( *ri == 'e' );
> >
> >     std::iterator_traits<std::string::reverse_iterator>::difference_type d;
> >     d = s.rend() - ri;
> > -   if (d != 5)
> > -      ++failures;
> > +   VERIFY( d == 5 );
> >
> >     const std::string cs("abcde");
> >     std::string::const_reverse_iterator cri(cs.rend());
> > -   if (cri - 5 != cs.rbegin())
> > -      ++failures;
> > -
> > -   return failures;
> > -}
> > -
> > -// the following should be compiler errors
> > -// flag runtime errors in case they slip through the compiler
> > -int
> > -wrong_stuff()
> > -{
> > -   int failures(0);
> > -
> > -#ifdef ITER24_F1
> > -   extern void f(std::vector<std::string*>::iterator);
> > -   std::vector<std::string*> vs[2];
> > -   f(vs);                       // address of array is not an iterator
> > -   failures++;
> > -#endif
> > -
> > -#ifdef ITER24_F2
> > -   std::string s;
> > -   char *i = s.begin();         // begin() doesn't return a pointer
> > -   failures++;
> > -#endif
> > -
> > -#ifdef ITER24_F3
> > -   std::string::const_iterator ci;
> > -   std::string::iterator i;
> > -   if (i - ci)                  // remove const_ is a warning
> > -      i++;
> > -   // failures++;  only a warning
> > -#endif
> > -
> > -#ifdef ITER24_F4
> > -   std::vector<char>::iterator iv;
> > -   std::string::iterator is(iv);// vector<char> is not string
> > -   failures++;
> > -#endif
> > -
> > -#ifdef ITER24_F5
> > -   std::vector<char>::iterator iv;
> > -   std::string::iterator is;
> > -   if (iv == is)                // vector<char> is not string
> > -      ++iv;
> > -   failures++;
> > -#endif
> > -
> > -#ifdef ITER24_F6
> > -   std::vector<char>::const_iterator ci;
> > -   std::vector<char>::iterator i = ci;  // remove const_ is a warning
> > -   ++i;
> > -   // failures++; only a warning
> > -#endif
> > -
> > -#ifdef ITER24_F7
> > -   std::vector<int> v(1);
> > -   std::vector<int>::const_iterator ci(v.begin());
> > -   *ci = 1;                     // cannot assign through const_iterator
> > -   failures++;
> > -#endif
> > -
> > -#ifdef ITER24_F8
> > -   std::vector<const int> v(1);
> > -   std::vector<const int>::reference r(v.begin()[0]);
> > -   r = 1;                       // cannot assign through reference to const
> > -   failures++;
> > -#endif
> > -
> > -   return failures;
> > +   VERIFY( cri - 5 == cs.rbegin() );
> >  }
> >
> >  // libstdc++/6642
> > -int
> > +void
> >  test6642()
> >  {
> >     std::string s;
> >     std::string::iterator it = s.begin();
> >     std::string::const_iterator cit = s.begin();
> > -
> > -   return it - cit;
> > +   VERIFY( (it - cit) == 0 );
> >  }
> >
> >  int
> >  main()
> >  {
> > -   int failures(0);
> > -
> > -   failures += string_stuff();
> > -
> > -   failures += vector_stuff();
> > -
> > -   failures += reverse_stuff();
> > -
> > -   failures += wrong_stuff();
> > -
> > -   failures += test6642();
> > -
> > -   VERIFY(failures == 0);
> > +   string_stuff();
> > +   vector_stuff();
> > +   reverse_stuff();
>
> There's no longer a call to test6642().
>
> I assume it's not intended to be a compile-only test that doesn't need
> to be run, because it uses VERIFY in a non-constexpr function.

(But thanks for the otherwise thorough clean-up of this test file!)

Reply via email to