// $Id$ // ============================================================================ // // = LIBRARY // tests // // = FILENAME // Map_Manager_Test.cpp // // = DESCRIPTION // This is a simple test of the and // that illustrates how to use the forward // and reverse iterators. // // = AUTHOR // Irfan Pyarali , // Douglas C. Schmidt , and // Kirthika Parameswaran // // ============================================================================ #include "test_config.h" #include "ace/Map_Manager.h" #include "ace/Hash_Map_Manager.h" #include "ace/Active_Map_Manager.h" #include "ace/Profile_Timer.h" #include "ace/Hash_Cache_Map_Manager_T.h" #include "ace/Caching_Strategies_T.h" #include "ace/Pair_T.h" ACE_RCSID(tests, Map_Manager_Test, "$Id$") typedef ACE_Null_Mutex MUTEX; typedef ACE_UINT32 TYPE; typedef ACE_Active_Map_Manager_Key ACTIVE_KEY; typedef ACE_Hash HASH_KEY; typedef ACE_Equal_To COMPARE_KEYS; typedef ACE_Map_Manager MAP_MANAGER; typedef ACE_Map_Iterator ITERATOR; typedef ACE_Map_Reverse_Iterator REVERSE_ITERATOR; typedef ACE_Map_Entry MAP_ENTRY; typedef ACE_Hash_Map_Manager_Ex HASH_MAP_MANAGER; typedef ACE_Hash_Map_Iterator_Ex HASH_ITERATOR; typedef ACE_Hash_Map_Reverse_Iterator_Ex HASH_REVERSE_ITERATOR; typedef ACE_Hash_Map_Entry HASH_ENTRY; typedef ACE_Active_Map_Manager ACTIVE_MAP_MANAGER; typedef ACE_Hash_Map_Manager_Ex, HASH_KEY, COMPARE_KEYS, MUTEX> CACHE_MAP_IMPL; typedef ACE_Hash_Map_Iterator_Ex, HASH_KEY, COMPARE_KEYS, MUTEX> CACHE_ITER_IMPL; typedef ACE_Hash_Map_Reverse_Iterator_Ex, HASH_KEY, COMPARE_KEYS, MUTEX> CACHE_REV_ITER_IMPL; typedef int ATTR; typedef ACE_Null_Cleanup_Strategy NULL_CLEANUP; typedef ACE_Null_Caching_Utility NULL_UTILITY; typedef ACE_Null_Caching_Strategy NULL_CACHING_STRATEGY; typedef ACE_Cache_Map_Manager CACHE_MAP_MANAGER; typedef ACE_Hash_Cache_Map_Manager HASH_CACHE_MAP_MANAGER; static void test_cache_map_manager (size_t table_size, size_t iterations, int test_iterators) { NULL_CACHING_STRATEGY null_caching_strategy; CACHE_MAP_MANAGER map (null_caching_strategy, table_size); TYPE i; TYPE j; ssize_t k; for (i = 0; i < iterations; i++) ACE_ASSERT (map.bind (i, i) != -1); if (test_iterators) { { i = 0; CACHE_MAP_MANAGER::ITERATOR end = map.end (); for (CACHE_MAP_MANAGER::ITERATOR iter = map.begin (); iter != end; ++iter) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, (*iter).first (), (*iter).second ())); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { k = iterations - 1; CACHE_MAP_MANAGER::REVERSE_ITERATOR rend = map.rend (); for (CACHE_MAP_MANAGER::REVERSE_ITERATOR iter = map.rbegin (); iter != rend; ++iter) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, (*iter).first (), (*iter).second ())); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } { i = 0; CACHE_MAP_MANAGER::iterator end = map.end (); for (CACHE_MAP_MANAGER::iterator iter = map.begin (); iter != end; ++iter) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, (*iter).first (), (*iter).second ())); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { k = iterations - 1; CACHE_MAP_MANAGER::reverse_iterator rend = map.rend (); for (CACHE_MAP_MANAGER::reverse_iterator iter = map.rbegin (); iter != rend; ++iter) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, (*iter).first (), (*iter).second ())); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } } for (i = 0; i < iterations; ++i) { ACE_ASSERT (map.find (i, j) != -1); ACE_ASSERT (i == j); } size_t remaining_entries = iterations; for (i = 0; i < iterations; ++i) { ACE_ASSERT (map.unbind (i) != -1); --remaining_entries; ACE_ASSERT (map.current_size () == remaining_entries); } } static void test_hash_cache_map_manager (size_t table_size, size_t iterations, int test_iterators) { NULL_CACHING_STRATEGY null_caching_strategy; HASH_CACHE_MAP_MANAGER map (null_caching_strategy, table_size); TYPE i; TYPE j; ssize_t k; for (i = 0; i < iterations; i++) ACE_ASSERT (map.bind (i, i) != -1); if (test_iterators) { { i = 0; HASH_CACHE_MAP_MANAGER::ITERATOR end = map.end (); for (HASH_CACHE_MAP_MANAGER::ITERATOR iter = map.begin (); iter != end; ++iter) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, (*iter).first (), (*iter).second ())); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { k = iterations - 1; HASH_CACHE_MAP_MANAGER::REVERSE_ITERATOR rend = map.rend (); for (HASH_CACHE_MAP_MANAGER::REVERSE_ITERATOR iter = map.rbegin (); iter != rend; ++iter) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, (*iter).first (), (*iter).second ())); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } { i = 0; HASH_CACHE_MAP_MANAGER::iterator end = map.end (); for (HASH_CACHE_MAP_MANAGER::iterator iter = map.begin (); iter != end; ++iter) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, (*iter).first (), (*iter).second ())); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { k = iterations - 1; HASH_CACHE_MAP_MANAGER::reverse_iterator rend = map.rend (); for (HASH_CACHE_MAP_MANAGER::reverse_iterator iter = map.rbegin (); iter != rend; ++iter) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, (*iter).first (), (*iter).second ())); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } } for (i = 0; i < iterations; ++i) { ACE_ASSERT (map.find (i, j) != -1); ACE_ASSERT (i == j); } size_t remaining_entries = iterations; for (i = 0; i < iterations; ++i) { ACE_ASSERT (map.unbind (i) != -1); --remaining_entries; ACE_ASSERT (map.current_size () == remaining_entries); } } static void test_active_map_manager (size_t table_size, size_t iterations, int test_iterators) { ACTIVE_MAP_MANAGER map (table_size); TYPE i; TYPE j; ssize_t k; ACTIVE_MAP_MANAGER::key_type *active_keys; ACE_NEW (active_keys, ACTIVE_MAP_MANAGER::key_type[iterations]); for (i = 0; i < iterations; i++) ACE_ASSERT (map.bind (i, active_keys[i]) != -1); if (test_iterators) { { i = 0; ACTIVE_MAP_MANAGER::iterator end = map.end (); for (ACTIVE_MAP_MANAGER::iterator iter = map.begin (); iter != end; ++iter) { ACTIVE_MAP_MANAGER::ENTRY &entry = *iter; ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d-%d|%d)"), i, entry.ext_id_.slot_index (), entry.ext_id_.slot_generation (), entry.int_id_)); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { k = iterations - 1; ACTIVE_MAP_MANAGER::reverse_iterator rend = map.rend (); for (ACTIVE_MAP_MANAGER::reverse_iterator iter = map.rbegin (); iter != rend; ++iter) { ACTIVE_MAP_MANAGER::ENTRY &entry = *iter; ACE_UNUSED_ARG (entry); ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d-%d|%d)"), k, entry.ext_id_.slot_index (), entry.ext_id_.slot_generation (), entry.int_id_)); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } } for (i = 0; i < iterations; ++i) { ACE_ASSERT (map.find (active_keys[i], j) != -1); ACE_ASSERT (i == j); } size_t remaining_entries = iterations; for (i = 0; i < iterations; ++i) { ACE_ASSERT (map.unbind (active_keys[i]) != -1); --remaining_entries; ACE_ASSERT (map.current_size () == remaining_entries); } delete [] active_keys; } static void test_hash_map_manager (size_t table_size, size_t iterations, int test_iterators) { HASH_MAP_MANAGER map (table_size); TYPE i; TYPE j; ssize_t k; for (i = 0; i < iterations; i++) ACE_ASSERT (map.bind (i, i) != -1); if (test_iterators) { { i = 0; HASH_ITERATOR end = map.end (); for (HASH_ITERATOR iter = map.begin (); iter != end; ++iter) { HASH_ENTRY &entry = *iter; ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, entry.ext_id_, entry.int_id_)); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { i = 0; HASH_ENTRY *entry = 0; for (HASH_ITERATOR iterator (map); iterator.next (entry) != 0; iterator.advance ()) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, entry->ext_id_, entry->int_id_)); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { k = iterations - 1; HASH_REVERSE_ITERATOR rend = map.rend (); for (HASH_REVERSE_ITERATOR iter = map.rbegin (); iter != rend; ++iter) { HASH_ENTRY &entry = *iter; ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, entry.ext_id_, entry.int_id_)); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } { k = iterations - 1; HASH_ENTRY *entry = 0; for (HASH_REVERSE_ITERATOR iterator (map); iterator.next (entry) != 0; iterator.advance ()) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, entry->ext_id_, entry->int_id_)); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } { i = 0; HASH_MAP_MANAGER::iterator end = map.end (); for (HASH_MAP_MANAGER::iterator iter = map.begin (); iter != end; ++iter) { HASH_MAP_MANAGER::ENTRY &entry = *iter; ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, entry.ext_id_, entry.int_id_)); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { i = 0; HASH_MAP_MANAGER::ENTRY *entry = 0; for (HASH_MAP_MANAGER::ITERATOR iterator (map); iterator.next (entry) != 0; iterator.advance ()) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, entry->ext_id_, entry->int_id_)); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { k = iterations - 1; HASH_MAP_MANAGER::reverse_iterator rend = map.rend (); for (HASH_MAP_MANAGER::reverse_iterator iter = map.rbegin (); iter != rend; ++iter) { HASH_MAP_MANAGER::ENTRY &entry = *iter; ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, entry.ext_id_, entry.int_id_)); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } { k = iterations - 1; HASH_MAP_MANAGER::ENTRY *entry = 0; for (HASH_MAP_MANAGER::REVERSE_ITERATOR iterator (map); iterator.next (entry) != 0; iterator.advance ()) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, entry->ext_id_, entry->int_id_)); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } } for (i = 0; i < iterations; ++i) { ACE_ASSERT (map.find (i, j) != -1); ACE_ASSERT (i == j); } size_t remaining_entries = iterations; for (i = 0; i < iterations; ++i) { ACE_ASSERT (map.unbind (i) != -1); --remaining_entries; ACE_ASSERT (map.current_size () == remaining_entries); } } static void test_map_manager (size_t table_size, size_t iterations, int test_iterators) { MAP_MANAGER map (table_size); TYPE i; TYPE j; ssize_t k; for (i = 0; i < iterations; ++i) ACE_ASSERT (map.bind (i, i) != -1); if (test_iterators) { { i = 0; ITERATOR end = map.end (); for (ITERATOR iter = map.begin (); iter != end; ++iter) { MAP_ENTRY &entry = *iter; ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, entry.ext_id_, entry.int_id_)); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { i = 0; MAP_ENTRY *entry = 0; for (ITERATOR iterator (map); iterator.next (entry) != 0; iterator.advance ()) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, entry->ext_id_, entry->int_id_)); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { k = iterations - 1; REVERSE_ITERATOR rend = map.rend (); for (REVERSE_ITERATOR iter = map.rbegin (); iter != rend; ++iter) { MAP_ENTRY &entry = *iter; ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, entry.ext_id_, entry.int_id_)); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } { k = iterations - 1; MAP_ENTRY *entry = 0; for (REVERSE_ITERATOR iterator (map); iterator.next (entry) != 0; iterator.advance ()) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, entry->ext_id_, entry->int_id_)); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } { i = 0; MAP_MANAGER::iterator end = map.end (); for (MAP_MANAGER::iterator iter = map.begin (); iter != end; ++iter) { MAP_MANAGER::ENTRY &entry = *iter; ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, entry.ext_id_, entry.int_id_)); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { i = 0; MAP_MANAGER::ENTRY *entry = 0; for (MAP_MANAGER::ITERATOR iterator (map); iterator.next (entry) != 0; iterator.advance ()) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), i, entry->ext_id_, entry->int_id_)); ++i; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (i == iterations); } { k = iterations - 1; MAP_MANAGER::reverse_iterator rend = map.rend (); for (MAP_MANAGER::reverse_iterator iter = map.rbegin (); iter != rend; ++iter) { MAP_ENTRY &entry = *iter; ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, entry.ext_id_, entry.int_id_)); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } { k = iterations - 1; MAP_MANAGER::ENTRY *entry = 0; for (MAP_MANAGER::REVERSE_ITERATOR iterator (map); iterator.next (entry) != 0; iterator.advance ()) { ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("(%d|%d|%d)"), k, entry->ext_id_, entry->int_id_)); k--; } ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("\n"))); ACE_ASSERT (k == -1); } } for (i = 0; i < iterations; ++i) { ACE_ASSERT (map.find (i, j) != -1); ACE_ASSERT (i == j); } size_t remaining_entries = iterations; for (i = 0; i < iterations; ++i) { ACE_ASSERT (map.unbind (i) != -1); --remaining_entries; ACE_ASSERT (map.current_size () == remaining_entries); } // // This is extra for the map manager. // for (i = 0; i < iterations; ++i) ACE_ASSERT (map.bind (i, i) != -1); // Unbind in one swoop. map.unbind_all (); ACE_ASSERT (map.current_size () == 0); for (i = 0; i < iterations; ++i) ACE_ASSERT (map.bind (i, i) != -1); // Unbind one at a time. MAP_MANAGER::iterator end = map.end (); while (1) { MAP_MANAGER::iterator iter = map.begin (); if (iter == end) break; ACE_ASSERT (map.unbind ((*iter).ext_id_) != -1); } ACE_ASSERT (map.current_size () == 0); } static void run_test (void (*ptf) (size_t, size_t, int), size_t table_size, size_t iterations, int test_iterators, const ACE_TCHAR *test_name) { ACE_Profile_Timer timer; timer.start (); (*ptf) (table_size, iterations, test_iterators); timer.stop (); ACE_Profile_Timer::ACE_Elapsed_Time et; timer.elapsed_time (et); ACE_TCHAR *test_iterators_string = 0; if (test_iterators) test_iterators_string = ACE_const_cast (ACE_TCHAR*, ACE_TEXT ( "includes executing iterators")); else test_iterators_string = ACE_const_cast (ACE_TCHAR*, ACE_TEXT ("doesn't include executing iterators")); ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("time to test a map of size %d for %d iterations using %s (%s)\n"), table_size, iterations, test_name, test_iterators_string)); ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("real time = %f secs, user time = %f secs, system time = %f secs\n"), et.real_time, et.user_time, et.system_time)); ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("time per call = %f usecs\n"), (et.real_time / ACE_timer_t (iterations)) * 1000000)); } int run_main (int argc, ACE_TCHAR *argv[]) { ACE_START_TEST (ACE_TEXT ("Map_Manager_Test")); ACE_LOG_MSG->clr_flags (ACE_Log_Msg::VERBOSE_LITE); size_t table_size = ACE_MAX_ITERATIONS / 2; size_t iterations = ACE_MAX_ITERATIONS; int test_iterators = 1; if (argc > 1) table_size = ACE_OS::atoi (argv[1]); if (argc > 2) iterations = ACE_OS::atoi (argv[2]); if (argc > 3) test_iterators = ACE_OS::atoi (argv[3]); // Test the . run_test (&test_map_manager, table_size, iterations, test_iterators, ACE_TEXT ("Map_Manager")); // Test the . run_test (&test_hash_map_manager, table_size, iterations, test_iterators, ACE_TEXT ("Hash_Map_Manager")); // Test the . run_test (&test_active_map_manager, table_size, iterations, test_iterators, ACE_TEXT ("Active_Map_Manager")); // Test the . run_test (&test_cache_map_manager, table_size, iterations, test_iterators, ACE_TEXT ("Cache_Map_Manager")); // Test the . run_test (&test_hash_cache_map_manager, table_size, iterations, test_iterators, ACE_TEXT ("Hash_Cache_Map_Manager")); ACE_LOG_MSG->set_flags (ACE_Log_Msg::VERBOSE_LITE); ACE_END_TEST; return 0; } #if defined (ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION) || \ defined (ACE_HAS_GNU_REPO) // The explicit instantiations are necessary with g++ 2.91.66 // with -frepo, because it misses some of them. template class ACE_Pair; template class ACE_Reference_Pair; template class ACE_Hash_Map_Manager_Ex; template class ACE_Hash_Map_Iterator_Base_Ex; template class ACE_Hash_Map_Iterator_Ex; template class ACE_Hash_Map_Reverse_Iterator_Ex; template class ACE_Hash_Map_Entry; template class ACE_Map_Manager; template class ACE_Map_Iterator_Base; template class ACE_Map_Iterator; template class ACE_Map_Reverse_Iterator; template class ACE_Map_Entry; template class ACE_Active_Map_Manager; template class ACE_Map_Manager; template class ACE_Map_Iterator_Base; template class ACE_Map_Iterator; template class ACE_Map_Reverse_Iterator; template class ACE_Map_Entry; template class ACE_Hash_Map_Manager_Ex, HASH_KEY, COMPARE_KEYS, MUTEX>; template class ACE_Hash_Map_Iterator_Base_Ex, HASH_KEY, COMPARE_KEYS, MUTEX>; template class ACE_Hash_Map_Iterator_Ex, HASH_KEY, COMPARE_KEYS, MUTEX>; template class ACE_Hash_Map_Reverse_Iterator_Ex, HASH_KEY, COMPARE_KEYS, MUTEX>; template class ACE_Hash_Map_Entry >; template class ACE_Cleanup_Strategy; template class ACE_Null_Cleanup_Strategy; template class ACE_Null_Caching_Utility; template class ACE_Null_Caching_Strategy; template class ACE_Hash_Cache_Map_Manager; template class ACE_Cache_Map_Manager; template class ACE_Cache_Map_Iterator; template class ACE_Cache_Map_Reverse_Iterator; #elif defined (ACE_HAS_TEMPLATE_INSTANTIATION_PRAGMA) #pragma instantiate ACE_Pair #pragma instantiate ACE_Reference_Pair #pragma instantiate ACE_Hash_Map_Manager_Ex #pragma instantiate ACE_Hash_Map_Iterator_Base_Ex #pragma instantiate ACE_Hash_Map_Iterator_Ex #pragma instantiate ACE_Hash_Map_Reverse_Iterator_Ex #pragma instantiate ACE_Hash_Map_Entry #pragma instantiate ACE_Map_Manager #pragma instantiate ACE_Map_Iterator_Base #pragma instantiate ACE_Map_Iterator #pragma instantiate ACE_Map_Reverse_Iterator #pragma instantiate ACE_Map_Entry #pragma instantiate ACE_Active_Map_Manager #pragma instantiate ACE_Map_Manager #pragma instantiate ACE_Map_Iterator_Base #pragma instantiate ACE_Map_Iterator #pragma instantiate ACE_Map_Reverse_Iterator #pragma instantiate ACE_Map_Entry #pragma instantiate ACE_Hash_Map_Manager_Ex, HASH_KEY, COMPARE_KEYS, MUTEX> #pragma instantiate ACE_Hash_Map_Iterator_Base_Ex, HASH_KEY, COMPARE_KEYS, MUTEX> #pragma instantiate ACE_Hash_Map_Iterator_Ex, HASH_KEY, COMPARE_KEYS, MUTEX> #pragma instantiate ACE_Hash_Map_Reverse_Iterator_Ex, HASH_KEY, COMPARE_KEYS, MUTEX> #pragma instantiate ACE_Hash_Map_Entry > #pragma instantiate ACE_Null_Cleanup_Strategy #pragma instantiate ACE_Cleanup_Strategy #pragma instantiate ACE_Null_Caching_Utility #pragma instantiate ACE_Null_Caching_Strategy #pragma instantiate ACE_Hash_Cache_Map_Manager #pragma instantiate ACE_Cache_Map_Manager #pragma instantiate ACE_Cache_Map_Iterator #pragma instantiate ACE_Cache_Map_Reverse_Iterator #endif /* ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION */