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