xref: /trunk/main/autodoc/inc/cosv/ploc.hxx (revision 914d351e5f5b84e4342a86d6ab8d4aca7308b9bd)
1*11c03c6dSDamjan Jovanovic /**************************************************************
2*11c03c6dSDamjan Jovanovic  *
3*11c03c6dSDamjan Jovanovic  * Licensed to the Apache Software Foundation (ASF) under one
4*11c03c6dSDamjan Jovanovic  * or more contributor license agreements.  See the NOTICE file
5*11c03c6dSDamjan Jovanovic  * distributed with this work for additional information
6*11c03c6dSDamjan Jovanovic  * regarding copyright ownership.  The ASF licenses this file
7*11c03c6dSDamjan Jovanovic  * to you under the Apache License, Version 2.0 (the
8*11c03c6dSDamjan Jovanovic  * "License"); you may not use this file except in compliance
9*11c03c6dSDamjan Jovanovic  * with the License.  You may obtain a copy of the License at
10*11c03c6dSDamjan Jovanovic  *
11*11c03c6dSDamjan Jovanovic  *   http://www.apache.org/licenses/LICENSE-2.0
12*11c03c6dSDamjan Jovanovic  *
13*11c03c6dSDamjan Jovanovic  * Unless required by applicable law or agreed to in writing,
14*11c03c6dSDamjan Jovanovic  * software distributed under the License is distributed on an
15*11c03c6dSDamjan Jovanovic  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*11c03c6dSDamjan Jovanovic  * KIND, either express or implied.  See the License for the
17*11c03c6dSDamjan Jovanovic  * specific language governing permissions and limitations
18*11c03c6dSDamjan Jovanovic  * under the License.
19*11c03c6dSDamjan Jovanovic  *
20*11c03c6dSDamjan Jovanovic  *************************************************************/
21*11c03c6dSDamjan Jovanovic 
22*11c03c6dSDamjan Jovanovic 
23*11c03c6dSDamjan Jovanovic 
24*11c03c6dSDamjan Jovanovic #ifndef CSV_PLOC_HXX
25*11c03c6dSDamjan Jovanovic #define CSV_PLOC_HXX
26*11c03c6dSDamjan Jovanovic 
27*11c03c6dSDamjan Jovanovic // USED SERVICES
28*11c03c6dSDamjan Jovanovic #include <cosv/string.hxx>
29*11c03c6dSDamjan Jovanovic #include <cosv/plocroot.hxx>
30*11c03c6dSDamjan Jovanovic #include <cosv/dirchain.hxx>
31*11c03c6dSDamjan Jovanovic #include <cosv/tpl/dyn.hxx>
32*11c03c6dSDamjan Jovanovic #include <cosv/csv_ostream.hxx>
33*11c03c6dSDamjan Jovanovic 
34*11c03c6dSDamjan Jovanovic 
35*11c03c6dSDamjan Jovanovic 
36*11c03c6dSDamjan Jovanovic 
37*11c03c6dSDamjan Jovanovic namespace csv
38*11c03c6dSDamjan Jovanovic {
39*11c03c6dSDamjan Jovanovic     class bostream;
40*11c03c6dSDamjan Jovanovic 
41*11c03c6dSDamjan Jovanovic namespace ploc
42*11c03c6dSDamjan Jovanovic {
43*11c03c6dSDamjan Jovanovic     class Root;
44*11c03c6dSDamjan Jovanovic 
45*11c03c6dSDamjan Jovanovic 
46*11c03c6dSDamjan Jovanovic /** Represents a path in the file system.
47*11c03c6dSDamjan Jovanovic 
48*11c03c6dSDamjan Jovanovic     The path can be relative or absolute and in Unix- or Windows-syntax.
49*11c03c6dSDamjan Jovanovic */
50*11c03c6dSDamjan Jovanovic class Path
51*11c03c6dSDamjan Jovanovic {
52*11c03c6dSDamjan Jovanovic   public:
53*11c03c6dSDamjan Jovanovic 
54*11c03c6dSDamjan Jovanovic     // LIFECYCLE
55*11c03c6dSDamjan Jovanovic     explicit            Path(
56*11c03c6dSDamjan Jovanovic                             const char *        i_sPath = ".",                  /// Dirs have to be ended with a '\\ or '/'.
57*11c03c6dSDamjan Jovanovic                             bool                i_bPathIsAlwaysDir = false,     /// This overrides a missing Delimiter at the end of the i_sPath, if true.
58*11c03c6dSDamjan Jovanovic                             const char *        i_sDelimiter = Delimiter() );
59*11c03c6dSDamjan Jovanovic                         Path(
60*11c03c6dSDamjan Jovanovic                             const Path &        i_rPath );
61*11c03c6dSDamjan Jovanovic                         ~Path();
62*11c03c6dSDamjan Jovanovic     // OPERATORS
63*11c03c6dSDamjan Jovanovic     Path &              operator=(
64*11c03c6dSDamjan Jovanovic                             const Path &        i_rPath );
65*11c03c6dSDamjan Jovanovic     // OPERATIONS
66*11c03c6dSDamjan Jovanovic     void                Set(
67*11c03c6dSDamjan Jovanovic                             const char *        i_sPath,
68*11c03c6dSDamjan Jovanovic                             bool                i_bPathIsAlwaysDir = false,
69*11c03c6dSDamjan Jovanovic                             const char *        i_sDelimiter = Delimiter() );
70*11c03c6dSDamjan Jovanovic     void                SetFile(                // If there is already a file, that is exchanged.
71*11c03c6dSDamjan Jovanovic                             const String &      i_sName );
72*11c03c6dSDamjan Jovanovic     // INQUIRY
RootDir() const73*11c03c6dSDamjan Jovanovic     const Root &        RootDir() const         { return *pRoot; }
74*11c03c6dSDamjan Jovanovic     const DirectoryChain &
DirChain() const75*11c03c6dSDamjan Jovanovic                         DirChain() const        { return aPath; }
File() const76*11c03c6dSDamjan Jovanovic     const String  &     File() const            { return sFile; }
77*11c03c6dSDamjan Jovanovic     const char *        FileExtension() const;
78*11c03c6dSDamjan Jovanovic     bool                IsValid() const;
IsDirectory() const79*11c03c6dSDamjan Jovanovic     bool                IsDirectory() const     { return sFile.length() == 0; }
IsFile() const80*11c03c6dSDamjan Jovanovic     bool                IsFile() const          { return sFile.length() > 0; }
81*11c03c6dSDamjan Jovanovic 
82*11c03c6dSDamjan Jovanovic     /// Directories have a delimiter at the end, files not.
83*11c03c6dSDamjan Jovanovic     void                Get(
84*11c03c6dSDamjan Jovanovic                             ostream &           o_rPath ) const;
85*11c03c6dSDamjan Jovanovic     /// Directories have a delimiter at the end, files not.
86*11c03c6dSDamjan Jovanovic     void                Get(
87*11c03c6dSDamjan Jovanovic                             bostream &          o_rPath ) const;
88*11c03c6dSDamjan Jovanovic     // ACCESS
DirChain()89*11c03c6dSDamjan Jovanovic     DirectoryChain &    DirChain()              { return aPath; }
90*11c03c6dSDamjan Jovanovic 
91*11c03c6dSDamjan Jovanovic   private:
92*11c03c6dSDamjan Jovanovic     Dyn<Root>           pRoot;
93*11c03c6dSDamjan Jovanovic     DirectoryChain      aPath;
94*11c03c6dSDamjan Jovanovic     String              sFile;
95*11c03c6dSDamjan Jovanovic };
96*11c03c6dSDamjan Jovanovic 
97*11c03c6dSDamjan Jovanovic 
98*11c03c6dSDamjan Jovanovic 
99*11c03c6dSDamjan Jovanovic 
100*11c03c6dSDamjan Jovanovic }   // namespace ploc
101*11c03c6dSDamjan Jovanovic }   // namespace csv
102*11c03c6dSDamjan Jovanovic 
103*11c03c6dSDamjan Jovanovic 
104*11c03c6dSDamjan Jovanovic 
105*11c03c6dSDamjan Jovanovic /// Directories produce a delimiter at the end, files not.
106*11c03c6dSDamjan Jovanovic inline csv::ostream &
operator <<(csv::ostream & o_rOut,const csv::ploc::Path & i_rPath)107*11c03c6dSDamjan Jovanovic operator<<( csv::ostream &           o_rOut,
108*11c03c6dSDamjan Jovanovic             const csv::ploc::Path &  i_rPath )
109*11c03c6dSDamjan Jovanovic {
110*11c03c6dSDamjan Jovanovic     i_rPath.Get(o_rOut);
111*11c03c6dSDamjan Jovanovic     return o_rOut;
112*11c03c6dSDamjan Jovanovic }
113*11c03c6dSDamjan Jovanovic 
114*11c03c6dSDamjan Jovanovic /// Directories produce a delimiter at the end, files not.
115*11c03c6dSDamjan Jovanovic inline csv::bostream &
operator <<(csv::bostream & o_rOut,const csv::ploc::Path & i_rPath)116*11c03c6dSDamjan Jovanovic operator<<( csv::bostream &         o_rOut,
117*11c03c6dSDamjan Jovanovic             const csv::ploc::Path & i_rPath )
118*11c03c6dSDamjan Jovanovic {
119*11c03c6dSDamjan Jovanovic     i_rPath.Get(o_rOut);
120*11c03c6dSDamjan Jovanovic     return o_rOut;
121*11c03c6dSDamjan Jovanovic }
122*11c03c6dSDamjan Jovanovic 
123*11c03c6dSDamjan Jovanovic 
124*11c03c6dSDamjan Jovanovic 
125*11c03c6dSDamjan Jovanovic #endif
126