1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski *
3*b1cdbd2cSJim Jagielski * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski * or more contributor license agreements. See the NOTICE file
5*b1cdbd2cSJim Jagielski * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski * regarding copyright ownership. The ASF licenses this file
7*b1cdbd2cSJim Jagielski * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski * with the License. You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski *
11*b1cdbd2cSJim Jagielski * http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski *
13*b1cdbd2cSJim Jagielski * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski * KIND, either express or implied. See the License for the
17*b1cdbd2cSJim Jagielski * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski * under the License.
19*b1cdbd2cSJim Jagielski *
20*b1cdbd2cSJim Jagielski *************************************************************/
21*b1cdbd2cSJim Jagielski
22*b1cdbd2cSJim Jagielski
23*b1cdbd2cSJim Jagielski
24*b1cdbd2cSJim Jagielski #ifndef ARY_NAMETREENODE_HXX
25*b1cdbd2cSJim Jagielski #define ARY_NAMETREENODE_HXX
26*b1cdbd2cSJim Jagielski // KORR_DEPRECATED_3.0
27*b1cdbd2cSJim Jagielski // Replace by ::ary::symtree::Node.
28*b1cdbd2cSJim Jagielski
29*b1cdbd2cSJim Jagielski // USED SERVICES
30*b1cdbd2cSJim Jagielski #include <cosv/tpl/tpltools.hxx>
31*b1cdbd2cSJim Jagielski #include <sci_impl.hxx>
32*b1cdbd2cSJim Jagielski // HACK because of SunPro 5.2 compiler bug with templates:
33*b1cdbd2cSJim Jagielski #include <ary/idl/i_module.hxx>
34*b1cdbd2cSJim Jagielski
35*b1cdbd2cSJim Jagielski
36*b1cdbd2cSJim Jagielski
37*b1cdbd2cSJim Jagielski
38*b1cdbd2cSJim Jagielski namespace ary
39*b1cdbd2cSJim Jagielski {
40*b1cdbd2cSJim Jagielski
41*b1cdbd2cSJim Jagielski
42*b1cdbd2cSJim Jagielski /** Implementation of a node in a namespace-tree.
43*b1cdbd2cSJim Jagielski */
44*b1cdbd2cSJim Jagielski template<class ITEM_ID>
45*b1cdbd2cSJim Jagielski class NameTreeNode
46*b1cdbd2cSJim Jagielski {
47*b1cdbd2cSJim Jagielski public:
48*b1cdbd2cSJim Jagielski typedef NameTreeNode self;
49*b1cdbd2cSJim Jagielski typedef ITEM_ID item_id;
50*b1cdbd2cSJim Jagielski typedef StringVector::const_iterator name_iterator;
51*b1cdbd2cSJim Jagielski typedef std::map<String, item_id> Map_LocalNames;
52*b1cdbd2cSJim Jagielski
53*b1cdbd2cSJim Jagielski // LIFECYCLE
54*b1cdbd2cSJim Jagielski NameTreeNode();
55*b1cdbd2cSJim Jagielski NameTreeNode(
56*b1cdbd2cSJim Jagielski const String & i_sName,
57*b1cdbd2cSJim Jagielski const self & i_rParent,
58*b1cdbd2cSJim Jagielski ITEM_ID i_nParentId );
59*b1cdbd2cSJim Jagielski virtual ~NameTreeNode();
60*b1cdbd2cSJim Jagielski
61*b1cdbd2cSJim Jagielski // OPERATIONS
62*b1cdbd2cSJim Jagielski void Add_Name(
63*b1cdbd2cSJim Jagielski const String & i_sName,
64*b1cdbd2cSJim Jagielski item_id i_nId );
65*b1cdbd2cSJim Jagielski // INQUIRY
Name() const66*b1cdbd2cSJim Jagielski const String & Name() const { return Depth() > 0 ? aCompleteNameChain.back() : String::Null_(); }
Parent() const67*b1cdbd2cSJim Jagielski item_id Parent() const { return nParent; }
Depth() const68*b1cdbd2cSJim Jagielski intt Depth() const { return aCompleteNameChain.size(); }
69*b1cdbd2cSJim Jagielski
70*b1cdbd2cSJim Jagielski bool IsEquivalent(
71*b1cdbd2cSJim Jagielski const NameTreeNode &
72*b1cdbd2cSJim Jagielski i_rNode ) const;
NameChain_Begin() const73*b1cdbd2cSJim Jagielski name_iterator NameChain_Begin() const { return aCompleteNameChain.begin(); }
NameChain_End() const74*b1cdbd2cSJim Jagielski name_iterator NameChain_End() const { return aCompleteNameChain.end(); }
75*b1cdbd2cSJim Jagielski
76*b1cdbd2cSJim Jagielski item_id Search_Name(
77*b1cdbd2cSJim Jagielski const String & i_sName ) const;
78*b1cdbd2cSJim Jagielski void Get_Names(
79*b1cdbd2cSJim Jagielski Dyn_StdConstIterator<ITEM_ID> &
80*b1cdbd2cSJim Jagielski o_rResult ) const;
81*b1cdbd2cSJim Jagielski const Map_LocalNames &
LocalNames() const82*b1cdbd2cSJim Jagielski LocalNames() const { return aLocalNames; }
83*b1cdbd2cSJim Jagielski private:
84*b1cdbd2cSJim Jagielski // Locals
LocalNames()85*b1cdbd2cSJim Jagielski Map_LocalNames & LocalNames() { return aLocalNames; }
86*b1cdbd2cSJim Jagielski
87*b1cdbd2cSJim Jagielski // DATA
88*b1cdbd2cSJim Jagielski Map_LocalNames aLocalNames;
89*b1cdbd2cSJim Jagielski StringVector aCompleteNameChain;
90*b1cdbd2cSJim Jagielski item_id nParent;
91*b1cdbd2cSJim Jagielski };
92*b1cdbd2cSJim Jagielski
93*b1cdbd2cSJim Jagielski
94*b1cdbd2cSJim Jagielski
95*b1cdbd2cSJim Jagielski
96*b1cdbd2cSJim Jagielski // IMPLEMENTATION
97*b1cdbd2cSJim Jagielski template<class ITEM_ID>
NameTreeNode()98*b1cdbd2cSJim Jagielski NameTreeNode<ITEM_ID>::NameTreeNode()
99*b1cdbd2cSJim Jagielski : aLocalNames(),
100*b1cdbd2cSJim Jagielski aCompleteNameChain(),
101*b1cdbd2cSJim Jagielski nParent(0)
102*b1cdbd2cSJim Jagielski {
103*b1cdbd2cSJim Jagielski }
104*b1cdbd2cSJim Jagielski
105*b1cdbd2cSJim Jagielski template<class ITEM_ID>
NameTreeNode(const String & i_sName,const self & i_rParent,ITEM_ID i_nParentId)106*b1cdbd2cSJim Jagielski NameTreeNode<ITEM_ID>::NameTreeNode( const String & i_sName,
107*b1cdbd2cSJim Jagielski const self & i_rParent,
108*b1cdbd2cSJim Jagielski ITEM_ID i_nParentId )
109*b1cdbd2cSJim Jagielski : aLocalNames(),
110*b1cdbd2cSJim Jagielski aCompleteNameChain(),
111*b1cdbd2cSJim Jagielski nParent(i_nParentId)
112*b1cdbd2cSJim Jagielski {
113*b1cdbd2cSJim Jagielski aCompleteNameChain.reserve(i_rParent.Depth()+1);
114*b1cdbd2cSJim Jagielski for ( name_iterator it = i_rParent.NameChain_Begin();
115*b1cdbd2cSJim Jagielski it != i_rParent.NameChain_End();
116*b1cdbd2cSJim Jagielski ++it )
117*b1cdbd2cSJim Jagielski {
118*b1cdbd2cSJim Jagielski aCompleteNameChain.push_back(*it);
119*b1cdbd2cSJim Jagielski }
120*b1cdbd2cSJim Jagielski aCompleteNameChain.push_back(i_sName);
121*b1cdbd2cSJim Jagielski }
122*b1cdbd2cSJim Jagielski
123*b1cdbd2cSJim Jagielski template<class ITEM_ID>
~NameTreeNode()124*b1cdbd2cSJim Jagielski NameTreeNode<ITEM_ID>::~NameTreeNode()
125*b1cdbd2cSJim Jagielski {
126*b1cdbd2cSJim Jagielski }
127*b1cdbd2cSJim Jagielski
128*b1cdbd2cSJim Jagielski
129*b1cdbd2cSJim Jagielski template<class ITEM_ID>
130*b1cdbd2cSJim Jagielski inline void
Add_Name(const String & i_sName,item_id i_nId)131*b1cdbd2cSJim Jagielski NameTreeNode<ITEM_ID>::Add_Name( const String & i_sName,
132*b1cdbd2cSJim Jagielski item_id i_nId )
133*b1cdbd2cSJim Jagielski {
134*b1cdbd2cSJim Jagielski LocalNames().insert( typename Map_LocalNames::value_type(i_sName, i_nId) );
135*b1cdbd2cSJim Jagielski }
136*b1cdbd2cSJim Jagielski
137*b1cdbd2cSJim Jagielski
138*b1cdbd2cSJim Jagielski template<class ITEM_ID>
139*b1cdbd2cSJim Jagielski inline bool
IsEquivalent(const NameTreeNode & i_rNode) const140*b1cdbd2cSJim Jagielski NameTreeNode<ITEM_ID>::IsEquivalent( const NameTreeNode & i_rNode ) const
141*b1cdbd2cSJim Jagielski {
142*b1cdbd2cSJim Jagielski return aCompleteNameChain == i_rNode.aCompleteNameChain;
143*b1cdbd2cSJim Jagielski }
144*b1cdbd2cSJim Jagielski
145*b1cdbd2cSJim Jagielski template<class ITEM_ID>
146*b1cdbd2cSJim Jagielski inline ITEM_ID
Search_Name(const String & i_sName) const147*b1cdbd2cSJim Jagielski NameTreeNode<ITEM_ID>::Search_Name( const String & i_sName ) const
148*b1cdbd2cSJim Jagielski {
149*b1cdbd2cSJim Jagielski return csv::value_from_map(LocalNames(),i_sName, ITEM_ID(0));
150*b1cdbd2cSJim Jagielski }
151*b1cdbd2cSJim Jagielski
152*b1cdbd2cSJim Jagielski template<class ITEM_ID>
153*b1cdbd2cSJim Jagielski inline void
Get_Names(Dyn_StdConstIterator<ITEM_ID> & o_rResult) const154*b1cdbd2cSJim Jagielski NameTreeNode<ITEM_ID>::Get_Names( Dyn_StdConstIterator<ITEM_ID> & o_rResult ) const
155*b1cdbd2cSJim Jagielski {
156*b1cdbd2cSJim Jagielski o_rResult = new SCI_DataInMap<String,item_id>(LocalNames());
157*b1cdbd2cSJim Jagielski }
158*b1cdbd2cSJim Jagielski
159*b1cdbd2cSJim Jagielski
160*b1cdbd2cSJim Jagielski // HACK because of SunPro 5.2 compiler bug with templates:
161*b1cdbd2cSJim Jagielski // ary::idl::Module has to be "FIND_NODE::node_type"
162*b1cdbd2cSJim Jagielski // must be solved later somehow.
163*b1cdbd2cSJim Jagielski template <class FIND_NODE>
164*b1cdbd2cSJim Jagielski typename FIND_NODE::id_type
Search_SubTree(const ary::idl::Module & i_rStart,const FIND_NODE & i_rNodeFinder)165*b1cdbd2cSJim Jagielski Search_SubTree( const ary::idl::Module & i_rStart,
166*b1cdbd2cSJim Jagielski const FIND_NODE & i_rNodeFinder )
167*b1cdbd2cSJim Jagielski {
168*b1cdbd2cSJim Jagielski const ary::idl::Module *
169*b1cdbd2cSJim Jagielski ret = &i_rStart;
170*b1cdbd2cSJim Jagielski
171*b1cdbd2cSJim Jagielski for ( StringVector::const_iterator it = i_rNodeFinder.Begin();
172*b1cdbd2cSJim Jagielski it != i_rNodeFinder.End() AND ret != 0;
173*b1cdbd2cSJim Jagielski ++it )
174*b1cdbd2cSJim Jagielski {
175*b1cdbd2cSJim Jagielski ret = i_rNodeFinder(ret->Search_Name(*it));
176*b1cdbd2cSJim Jagielski }
177*b1cdbd2cSJim Jagielski
178*b1cdbd2cSJim Jagielski typename FIND_NODE::id_type nret(0);
179*b1cdbd2cSJim Jagielski return ret != 0
180*b1cdbd2cSJim Jagielski ? ret->Search_Name(i_rNodeFinder.Name2Search())
181*b1cdbd2cSJim Jagielski : nret;
182*b1cdbd2cSJim Jagielski }
183*b1cdbd2cSJim Jagielski
184*b1cdbd2cSJim Jagielski template <class FIND_NODE>
185*b1cdbd2cSJim Jagielski typename FIND_NODE::id_type
Search_SubTree_UpTillRoot(const ary::idl::Module & i_rStart,const FIND_NODE & i_rNodeFinder)186*b1cdbd2cSJim Jagielski Search_SubTree_UpTillRoot( const ary::idl::Module & i_rStart,
187*b1cdbd2cSJim Jagielski const FIND_NODE & i_rNodeFinder )
188*b1cdbd2cSJim Jagielski {
189*b1cdbd2cSJim Jagielski typename FIND_NODE::id_type
190*b1cdbd2cSJim Jagielski ret(0);
191*b1cdbd2cSJim Jagielski for ( const ary::idl::Module * start = &i_rStart;
192*b1cdbd2cSJim Jagielski start != 0 AND NOT ret.IsValid();
193*b1cdbd2cSJim Jagielski start = i_rNodeFinder(start->Owner()) )
194*b1cdbd2cSJim Jagielski {
195*b1cdbd2cSJim Jagielski ret = Search_SubTree( *start,
196*b1cdbd2cSJim Jagielski i_rNodeFinder );
197*b1cdbd2cSJim Jagielski }
198*b1cdbd2cSJim Jagielski return ret;
199*b1cdbd2cSJim Jagielski }
200*b1cdbd2cSJim Jagielski // END Hack for SunPro 5.2 compiler bug.
201*b1cdbd2cSJim Jagielski
202*b1cdbd2cSJim Jagielski
203*b1cdbd2cSJim Jagielski
204*b1cdbd2cSJim Jagielski
205*b1cdbd2cSJim Jagielski } // namespace ary
206*b1cdbd2cSJim Jagielski #endif
207