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 ADC_DISPLAY_OUT_TREE_HXX
25*b1cdbd2cSJim Jagielski #define ADC_DISPLAY_OUT_TREE_HXX
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski // USED SERVICES
29*b1cdbd2cSJim Jagielski     // BASE CLASSES
30*b1cdbd2cSJim Jagielski     // COMPONENTS
31*b1cdbd2cSJim Jagielski #include "out_position.hxx"
32*b1cdbd2cSJim Jagielski     // PARAMETERS
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski 
35*b1cdbd2cSJim Jagielski namespace output
36*b1cdbd2cSJim Jagielski {
37*b1cdbd2cSJim Jagielski 
38*b1cdbd2cSJim Jagielski inline const char *
ModuleFileName()39*b1cdbd2cSJim Jagielski ModuleFileName()
40*b1cdbd2cSJim Jagielski { return "module-ix.html"; }
41*b1cdbd2cSJim Jagielski inline const char *
IndexFilesDirName()42*b1cdbd2cSJim Jagielski IndexFilesDirName()
43*b1cdbd2cSJim Jagielski { return "index-files"; }
44*b1cdbd2cSJim Jagielski inline const char *
IndexFile_A()45*b1cdbd2cSJim Jagielski IndexFile_A()
46*b1cdbd2cSJim Jagielski { return "index-1.html"; }
47*b1cdbd2cSJim Jagielski 
48*b1cdbd2cSJim Jagielski 
49*b1cdbd2cSJim Jagielski class Tree
50*b1cdbd2cSJim Jagielski {
51*b1cdbd2cSJim Jagielski   public:
52*b1cdbd2cSJim Jagielski     // LIFECYCLE
53*b1cdbd2cSJim Jagielski                         Tree();
54*b1cdbd2cSJim Jagielski                         ~Tree();
55*b1cdbd2cSJim Jagielski 
56*b1cdbd2cSJim Jagielski     // OPERATIONS
57*b1cdbd2cSJim Jagielski     void                Set_Overview(
58*b1cdbd2cSJim Jagielski                             const StringVector &
59*b1cdbd2cSJim Jagielski                                                 i_path,
60*b1cdbd2cSJim Jagielski                             const String &      i_sFileName );
61*b1cdbd2cSJim Jagielski     Node &              Set_NamesRoot(
62*b1cdbd2cSJim Jagielski                             const StringVector &
63*b1cdbd2cSJim Jagielski                                                 i_path );
64*b1cdbd2cSJim Jagielski     Node &              Set_IndexRoot(
65*b1cdbd2cSJim Jagielski                             const StringVector &
66*b1cdbd2cSJim Jagielski                                                 i_path );
67*b1cdbd2cSJim Jagielski     Node &              Set_ProjectsRoot(
68*b1cdbd2cSJim Jagielski                             const StringVector &
69*b1cdbd2cSJim Jagielski                                                 i_path );
70*b1cdbd2cSJim Jagielski     Node &              Provide_Node(
71*b1cdbd2cSJim Jagielski                             const StringVector &
72*b1cdbd2cSJim Jagielski                                                 i_path );
73*b1cdbd2cSJim Jagielski 
74*b1cdbd2cSJim Jagielski     // ACCESS
RootNode()75*b1cdbd2cSJim Jagielski     Node &              RootNode()              { return *pRoot; }
NamesRootNode()76*b1cdbd2cSJim Jagielski     Node &              NamesRootNode()	    	{ return *pNamesRoot; }
IndexRootNode()77*b1cdbd2cSJim Jagielski     Node &              IndexRootNode()			{ return *pIndexRoot; }
ProjectsRootNode()78*b1cdbd2cSJim Jagielski     Node &              ProjectsRootNode()		{ return *pProjectsRoot; }
79*b1cdbd2cSJim Jagielski 
Root()80*b1cdbd2cSJim Jagielski     Position            Root()                  { return Position(*pRoot); }
Overview()81*b1cdbd2cSJim Jagielski     Position            Overview()				{ return aOverview; }
NamesRoot()82*b1cdbd2cSJim Jagielski     Position            NamesRoot()				{ return Position(*pNamesRoot); }
IndexRoot()83*b1cdbd2cSJim Jagielski     Position            IndexRoot()				{ return Position(*pIndexRoot); }
ProjectsRoot()84*b1cdbd2cSJim Jagielski     Position            ProjectsRoot()			{ return Position(*pProjectsRoot); }
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski   private:
87*b1cdbd2cSJim Jagielski     // forbidden:
88*b1cdbd2cSJim Jagielski                         Tree(const Tree&);
89*b1cdbd2cSJim Jagielski     Tree &              operator=(const Tree&);
90*b1cdbd2cSJim Jagielski 
91*b1cdbd2cSJim Jagielski     // DATA
92*b1cdbd2cSJim Jagielski     Dyn<Node>           pRoot;
93*b1cdbd2cSJim Jagielski     Node *              pNamesRoot;
94*b1cdbd2cSJim Jagielski     Node *              pIndexRoot;
95*b1cdbd2cSJim Jagielski     Node *              pProjectsRoot;
96*b1cdbd2cSJim Jagielski     Position            aOverview;
97*b1cdbd2cSJim Jagielski };
98*b1cdbd2cSJim Jagielski 
99*b1cdbd2cSJim Jagielski 
100*b1cdbd2cSJim Jagielski // IMPLEMENTATION
101*b1cdbd2cSJim Jagielski 
102*b1cdbd2cSJim Jagielski inline Node &
Provide_Node(const StringVector & i_path)103*b1cdbd2cSJim Jagielski Tree::Provide_Node( const StringVector & i_path )
104*b1cdbd2cSJim Jagielski     { return pRoot->Provide_Child(i_path); }
105*b1cdbd2cSJim Jagielski 
106*b1cdbd2cSJim Jagielski 
107*b1cdbd2cSJim Jagielski inline void
Set_Overview(const StringVector & i_path,const String & i_sFileName)108*b1cdbd2cSJim Jagielski Tree::Set_Overview( const StringVector & i_path,
109*b1cdbd2cSJim Jagielski                     const String &		 i_sFileName )
110*b1cdbd2cSJim Jagielski     { aOverview.Set(Provide_Node(i_path), i_sFileName); }
111*b1cdbd2cSJim Jagielski 
112*b1cdbd2cSJim Jagielski inline Node &
Set_NamesRoot(const StringVector & i_path)113*b1cdbd2cSJim Jagielski Tree::Set_NamesRoot( const StringVector & i_path )
114*b1cdbd2cSJim Jagielski     { pNamesRoot = &Provide_Node(i_path);
115*b1cdbd2cSJim Jagielski 	  return *pNamesRoot; }
116*b1cdbd2cSJim Jagielski 
117*b1cdbd2cSJim Jagielski inline Node &
Set_IndexRoot(const StringVector & i_path)118*b1cdbd2cSJim Jagielski Tree::Set_IndexRoot( const StringVector & i_path )
119*b1cdbd2cSJim Jagielski     { pIndexRoot = &Provide_Node(i_path);
120*b1cdbd2cSJim Jagielski 	  return *pIndexRoot; }
121*b1cdbd2cSJim Jagielski 
122*b1cdbd2cSJim Jagielski inline Node &
Set_ProjectsRoot(const StringVector & i_path)123*b1cdbd2cSJim Jagielski Tree::Set_ProjectsRoot( const StringVector & i_path )
124*b1cdbd2cSJim Jagielski     { pProjectsRoot = &Provide_Node(i_path);
125*b1cdbd2cSJim Jagielski 	  return *pProjectsRoot; }
126*b1cdbd2cSJim Jagielski 
127*b1cdbd2cSJim Jagielski 
128*b1cdbd2cSJim Jagielski 
129*b1cdbd2cSJim Jagielski }   // namespace output
130*b1cdbd2cSJim Jagielski 
131*b1cdbd2cSJim Jagielski 
132*b1cdbd2cSJim Jagielski #endif
133