stdcpp/tsrc/Stdcpp_test/stlport/auto/stlport_setsymd/src/setsymd2.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 11 Jun 2010 15:26:22 +0300
changeset 34 5fae379060a7
parent 31 ce057bb09d0b
child 45 4b03adbd26ca
permissions -rw-r--r--
Revision: 201023 Kit: 2010123


// STLport regression testsuite component.
// To compile as a separate example, please #define MAIN.

#include <algorithm>
#include <iostream>
#include <cstring>
#include <iterator>
#include <functional>

#ifdef MAIN 
#define setsymd2_test main
#endif

#if !defined (STLPORT) || defined(__STL_USE_NAMESPACES)
using namespace std;
#endif
int setsymd2_test(int, char**)
{
  int failures=0;
  cout<<"Results of setsymd2_test:"<<endl;
char* word1 = "ABCDEFGHIJKLMNO";
char* word2 = "LMNOPQRSTUVWXYZ";
char word3[23];
  ostream_iterator <char> iter(cout, " ");
  cout << "word1: ";
  
  if(strcmp(word1,"ABCDEFGHIJKLMNO"))
    failures++;
  copy(word1, word1 + ::strlen(word1), iter);
  cout << "\nword2: ";
  
  if(strcmp(word2,"LMNOPQRSTUVWXYZ"))
    failures++;
  copy(word2, word2 + ::strlen(word2), iter);
  cout << endl;
  set_symmetric_difference(word1, word1 + ::strlen(word1),
                            word2, word2 + ::strlen(word2),
                            word3,
                            less<char>());
  word3[22]='\0';
  if(strcmp(word3,"ABCDEFGHIJKPQRSTUVWXYZ"))
     failures++;
  copy(word3,word3+ ::strlen(word3),iter);  
  cout << endl;
  
  if(failures)
    return 1;
  else  
    return 0;
}