home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / stlpt453.zip / STLport-4.5.3 / test / regression / search2.cpp < prev    next >
C/C++ Source or Header  |  2001-05-18  |  2KB  |  67 lines

  1. // STLport regression testsuite component.
  2. // To compile as a separate example, please #define MAIN.
  3.  
  4. #include <algorithm>
  5. #include <iostream>
  6. #include <cstring>
  7. #include <iterator>
  8. #include <functional>
  9.  
  10. #if !defined (STLPORT) || defined(__STL_USE_NAMESPACES)
  11. using namespace std;
  12. #endif
  13.  
  14. #ifdef MAIN 
  15. #define search2_test main
  16. #endif
  17. static bool str_equal(const char* a_, const char* b_)
  18. {
  19.   return strcmp(a_, b_) == 0 ? 1 : 0;
  20. }
  21.  
  22. int search2_test(int, char**)
  23. {
  24.   cout<<"Results of search2_test:"<<endl;
  25.  
  26. char* grades[] = { "A", "B", "C", "D", "F" };
  27. char* letters[] = { "Q", "E", "D" };
  28.  
  29.   const unsigned gradeCount = sizeof(grades) / sizeof(grades[0]);
  30.   const unsigned letterCount = sizeof(letters) / sizeof(letters[0]);
  31.   ostream_iterator <char*> iter(cout, " ");
  32.   cout << "grades: ";
  33.   copy(grades, grades + gradeCount, iter);
  34.   cout << "\nletters:";
  35.   copy(letters, letters + letterCount, iter);
  36.   cout << endl;
  37.  
  38.   char** location =
  39.     search((char**)grades, (char**)grades + gradeCount,
  40.             (char**)letters, (char**)letters + letterCount,
  41.             str_equal);
  42.  
  43.   if(location == grades + gradeCount)
  44.     cout << "letters not found in grades" << endl;
  45.   else
  46.     cout << "letters found in grades at offset: " << location - grades << endl;
  47.  
  48.   copy((char**)grades + 1, (char**)grades + 1 + letterCount, (char**)letters);
  49.  
  50.   cout << "grades: ";
  51.   copy(grades, grades + gradeCount, iter);
  52.   cout << "\nletters:";
  53.   copy(letters, letters + letterCount, iter);
  54.   cout << endl;
  55.  
  56.   location = search((char**)grades, (char**)grades + gradeCount,
  57.                      (char**)letters, (char**)letters + letterCount,
  58.                      str_equal);
  59.  
  60.   if(location == grades + gradeCount)
  61.     cout << "letters not found in grades" << endl;
  62.   else
  63.     cout
  64.       << "letters found in grades at offset: " << location - grades << endl;
  65.   return 0;
  66. }
  67.