Merge branch 'master' of ssh://git.code.sf.net/p/foam-extend/foam-extend-3.2
[foam-extend-3.2.git] / src / foam / db / Time / TimePaths.H
blob1af983c5eda1db34912dfe2dff452124c2138b24
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | foam-extend: Open Source CFD
4    \\    /   O peration     | Version:     3.2
5     \\  /    A nd           | Web:         http://www.foam-extend.org
6      \\/     M anipulation  | For copyright notice see file Copyright
7 -------------------------------------------------------------------------------
8 License
9     This file is part of foam-extend.
11     foam-extend is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by the
13     Free Software Foundation, either version 3 of the License, or (at your
14     option) any later version.
16     foam-extend is distributed in the hope that it will be useful, but
17     WITHOUT ANY WARRANTY; without even the implied warranty of
18     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
19     General Public License for more details.
21     You should have received a copy of the GNU General Public License
22     along with foam-extend.  If not, see <http://www.gnu.org/licenses/>.
24 Class
25     Foam::TimePaths
27 Description
28     A class for addressing time paths without using the Time class.
30 SourceFiles
31     TimePaths.C
33 \*---------------------------------------------------------------------------*/
35 #ifndef TimePaths_H
36 #define TimePaths_H
38 #include "fileName.H"
40 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
42 namespace Foam
45 /*---------------------------------------------------------------------------*\
46                            Class TimePaths Declaration
47 \*---------------------------------------------------------------------------*/
50 class TimePaths
52     // Private data
54         bool processorCase_;
55         fileName rootPath_;
56         fileName case_;
57         word system_;
58         word constant_;
61 public:
63     // Constructors
65         //- Construct given database name, rootPath and casePath
66         TimePaths
67         (
68             const fileName& rootPath,
69             const fileName& caseName,
70             const word& systemName,
71             const word& constantName
72         );
75     // Member functions
77             //- Return true if this is a processor case
78             bool processorCase() const
79             {
80                 return processorCase_;
81             }
83             //- Return root path
84             const fileName& rootPath() const
85             {
86                 return rootPath_;
87             }
89             //- Return case name
90             const fileName& caseName() const
91             {
92                 return case_;
93             }
95             //- Return system name
96             const word& system() const
97             {
98                 return system_;
99             }
101             //- Return system name for the case
102             //  which for parallel runs returns ../system()
103             fileName caseSystem() const;
105             //- Return constant name
106             const word& constant() const
107             {
108                 return constant_;
109             }
111             //- Return constant name for the case
112             //  which for parallel runs returns ../constant()
113             fileName caseConstant() const;
115             //- Return path
116             fileName path() const
117             {
118                 return rootPath()/caseName();
119             }
121             //- Return system path
122             fileName systemPath() const
123             {
124                 return path()/system();
125             }
127             //- Return constant path
128             fileName constantPath() const
129             {
130                 return path()/constant();
131             }
135 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
137 } // End namespace Foam
139 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
141 #endif
143 // ************************************************************************* //