summaryrefslogtreecommitdiff
path: root/tests/Map_Manager_Test.cpp
blob: 51f4f8dc193fae6678024f2c7c4c3f3c6323d849 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// $Id$

// ============================================================================
//
// = LIBRARY
//    tests
// 
// = FILENAME
//    Map_Manager_Test.cpp
//
// = DESCRIPTION
//      This is a simple test of the ACE_Map_Manager that
//      illustrates how to use the forward and reverse iterators. 
//
// = AUTHOR
//    Irfan Pyarali
// 
// ============================================================================

#include "ace/Map_Manager.h"
#include "ace/Synch.h"
#include "test_config.h"

typedef ACE_Null_Mutex MUTEX;
typedef int KEY;
typedef int VALUE;

typedef ACE_Map_Manager <KEY, VALUE, MUTEX> MAP_MANAGER;
typedef ACE_Map_Iterator <KEY, VALUE, MUTEX> ITERATOR;
typedef ACE_Map_Reverse_Iterator <KEY, VALUE, MUTEX> REVERSE_ITERATOR;
typedef ACE_Map_Entry <KEY, VALUE> ENTRY;

int 
main (int, char *argv[])
{
  ACE_START_TEST ("Map_Manager_Test");

  const int ITERATIONS = 5;
  MAP_MANAGER map;

  for (VALUE i = 1; i <= ITERATIONS; i++)
    {
      if (map.bind (i, i) != 0)
	ACE_ERROR_RETURN ((LM_ERROR, "MAP_MANAGER::bind"), -1);
    }

  ACE_DEBUG ((LM_DEBUG, "\nForward Iterations\n"));
  {
    ITERATOR iterator (map);  
    for (ENTRY *entry = 0;
	 iterator.next (entry) != 0;
	 iterator.advance ())
      {
	ACE_DEBUG ((LM_DEBUG, "%d %d\n", entry->ext_id_, entry->int_id_));
      }  
  }

  ACE_DEBUG ((LM_DEBUG, "\nReverse Iterations\n"));
  {
    REVERSE_ITERATOR iterator (map);
    for (ENTRY *entry = 0;
	 iterator.next (entry) != 0;
	 iterator.advance ())
      {
	ACE_DEBUG ((LM_DEBUG, "%d %d\n", entry->ext_id_, entry->int_id_));
      }  
  }

  ACE_DEBUG ((LM_DEBUG, "\nForward Iterations\n"));
  {
    MAP_MANAGER::ITERATOR iterator (map);
    for (MAP_MANAGER::ENTRY *entry = 0;
	 iterator.next (entry) != 0;
	 iterator.advance ())
      {
	ACE_DEBUG ((LM_DEBUG, "%d %d\n", entry->ext_id_, entry->int_id_));
      }  
  }

  ACE_DEBUG ((LM_DEBUG, "\nReverse Iterations\n"));
  {
    MAP_MANAGER::REVERSE_ITERATOR iterator (map);
    for (MAP_MANAGER::ENTRY *entry = 0;
	 iterator.next (entry) != 0;
	 iterator.advance ())
      {
	ACE_DEBUG ((LM_DEBUG, "%d %d\n", entry->ext_id_, entry->int_id_));
      }  
  }

  ACE_END_TEST;
  return 0;
}