⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 test_slist.cpp

📁 symbian 上的stl_port进过编译的。
💻 CPP
字号:
/***********************************************************************************  test_slist.cpp * Copyright (c) 1997 * Mark of the Unicorn, Inc. * * Permission to use, copy, modify, distribute and sell this software * and its documentation for any purpose is hereby granted without fee, * provided that the above copyright notice appear in all copies and * that both that copyright notice and this permission notice appear * in supporting documentation.  Mark of the Unicorn makes no * representations about the suitability of this software for any * purpose.  It is provided "as is" without express or implied warranty.***********************************************************************************/#include "Tests.h"#if defined( EH_SLIST_IMPLEMENTED )#  include "TestClass.h"#  include "LeakCheck.h"#  if defined (EH_NEW_HEADERS) && defined (EH_USE_SGI_STL)#    include <slist>#  else#    include <slist.h>#  endif#include "test_construct.h"#include "test_assign_op.h"#include "test_push_back.h"#include "test_insert.h"#include "test_push_front.h"#if defined (__GNUC__) && defined (__APPLE__)typedef EH_STD::slist<TestClass, eh_allocator(TestClass) > TestSList;#elsetypedef EH_STD::__slist__<TestClass, eh_allocator(TestClass) > TestSList;#endifinline sequence_container_tagcontainer_category(const TestSList&) {  return sequence_container_tag();}struct test_slist_sort {  test_slist_sort() {    gTestController.SetCurrentTestName("slist::sort()");  }  void operator()( TestSList& slist ) const {    slist.sort();    for ( TestSList::iterator p = slist.begin(), q; p != slist.end(); q = p, p++ )      if ( p != slist.begin() )        EH_ASSERT( *p >= *q );  }};void test_slist() {  TestSList testSList, testSList2;  size_t slistSize = random_number(random_base);  while (testSList.size() < slistSize) {    TestClass x;    testSList.push_front( x );    testSList2.push_front( TestClass() );  }  StrongCheck( testSList, test_insert_one<TestSList>(testSList) );  StrongCheck( testSList, test_insert_one<TestSList>(testSList, 0) );  StrongCheck( testSList, test_insert_one<TestSList>(testSList, (int)testSList.size()) );  WeakCheck( testSList, test_insert_n<TestSList>(testSList, random_number(random_base) ) );  WeakCheck( testSList, test_insert_n<TestSList>(testSList, random_number(random_base), 0 ) );  WeakCheck( testSList, test_insert_n<TestSList>(testSList, random_number(random_base), (int)testSList.size() ) );  size_t insCnt = random_number(random_base);  TestClass *insFirst = _CHECK_PTR(new TestSList::value_type[1+insCnt]);  WeakCheck( testSList, insert_range_tester(testSList, insFirst, insFirst+insCnt) );  ConstCheck( 0, test_construct_pointer_range<TestSList>(insFirst, insFirst+insCnt) );  delete[] insFirst;  WeakCheck( testSList, test_insert_range<TestSList,TestSList::iterator>(testSList, testSList2.begin(), testSList2.end() ) );  StrongCheck( testSList, test_push_front<TestSList>(testSList) );  StrongCheck( testSList, test_slist_sort() );  // Simply to verify strength.  ConstCheck( 0, test_default_construct<TestSList>() );  ConstCheck( 0, test_construct_n<TestSList>( random_number(random_base) ) );  ConstCheck( 0, test_construct_n_instance<TestSList>( random_number(random_base) ) );  ConstCheck( 0, test_construct_iter_range<TestSList>( testSList2 ) );  ConstCheck( testSList, test_copy_construct<TestSList>() );  WeakCheck( testSList, test_assign_op<TestSList>( testSList2 ) );}#endif // EH_SLIST_IMPLEMENTED

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -