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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
// -*- C++ -*-
//
//=============================================================================
/**
* @file PG_Object_Group_Map.cpp
*
* $Id$
*
* Container for TAO::PG_Object_Groups indexed by ObjectGroupId
* Note this was developed as part of FT CORBA
* @@ For now its but one of several parallel containers for object group information
* @@ TODO: Combine these parallel containers into a single one that consolidates everything
* @@ known about object groups.
* @author Dale Wilson <wilson_d@ociweb.com>
*/
//=============================================================================
#include "PG_Object_Group_Map.h"
#include "PG_Object_Group.h"
#include <orbsvcs/orbsvcs/PortableGroup/PG_Utils.h>
TAO::PG_Object_Group_Map::PG_Object_Group_Map ()
{
}
TAO::PG_Object_Group_Map::~PG_Object_Group_Map ()
{
// todo: destroy all members
}
//////////////////////////////////////////////////////
// PG_Object_Group_Map public methods
// insert group. Take ownership
int TAO::PG_Object_Group_Map::insert_group ( ::TAO::PG_Object_Group * group)
{
return insert_group (group->get_object_group_id(), group);
}
int TAO::PG_Object_Group_Map::insert_group (PortableGroup::ObjectGroupId group_id, ::TAO::PG_Object_Group * group)
{
return (this->bind (group_id, group) == 0);
}
int TAO::PG_Object_Group_Map::find_group (PortableGroup::ObjectGroupId group_id, ::TAO::PG_Object_Group *& group) const
{
return (this->find (group_id , group) == 0);
}
int TAO::PG_Object_Group_Map::find_group (PortableGroup::ObjectGroup_ptr object_group, ::TAO::PG_Object_Group *& group) const
{
int result = 0;
PortableGroup::TagGroupTaggedComponent tc;
if (TAO::PG_Utils::get_tagged_component (object_group, tc))
{
result = find_group (tc.object_group_id, group);
}
return result;
}
int TAO::PG_Object_Group_Map::destroy_group (PortableGroup::ObjectGroupId group_id)
{
::TAO::PG_Object_Group * group;
int result = (this->unbind (group_id, group) == 0);
if (result)
{
delete group;
}
return result;
}
int TAO::PG_Object_Group_Map::destroy_group (PortableGroup::ObjectGroup_ptr object_group)
{
PortableGroup::TagGroupTaggedComponent tc;
TAO::PG_Utils::get_tagged_component (object_group, tc);
return destroy_group (tc.object_group_id);
}
#if defined (ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION)
template class ACE_Hash_Map_Manager_Ex<
PortableGroup::ObjectGroupId,
::TAO::PG_Object_Group *,
ACE_Hash<ACE_UINT64>,
ACE_Equal_To<ACE_UINT64>,
TAO_SYNCH_MUTEX>;
template class ACE_Hash_Map_Entry <
PortableGroup::ObjectGroupId,
::TAO::PG_Object_Group *>;
template class ACE_Hash_Map_Iterator_Ex <
PortableGroup::ObjectGroupId,
::TAO::PG_Object_Group *,
ACE_Hash<ACE_UINT64>,
ACE_Equal_To<ACE_UINT64>,
TAO_SYNCH_MUTEX>;
#elif defined (ACE_HAS_TEMPLATE_INSTANTIATION_PRAGMA)
# pragma instantiate ACE_Hash_Map_Manager_Ex<
PortableGroup::ObjectGroupId,
::TAO::PG_Object_Group *,
ACE_Hash<ACE_UINT64>,
ACE_Equal_To<ACE_UINT64>,
TAO_SYNCH_MUTEX>;
# pragma instantiate ACE_Hash_Map_Entry <
PortableGroup::ObjectGroupId,
::TAO::PG_Object_Group *>;
# pragma instantiate ACE_Hash_Map_Iterator_Ex <
PortableGroup::ObjectGroupId,
::TAO::PG_Object_Group *,
ACE_Hash<ACE_UINT64>,
ACE_Equal_To<ACE_UINT64>,
TAO_SYNCH_MUTEX>;
#endif /* ACE_HAS_EXPLICIT_TEMPLATE_INSTANTIATION */
|