initial commit for version 1.5.x patch release
[OpenFOAM-1.5.x.git] / src / OpenFOAM / db / Time / findTimes.C
blob5e83e115fdbfc8ca2626d51550acb4ab79aede97
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 1991-2008 OpenCFD Ltd.
6      \\/     M anipulation  |
7 -------------------------------------------------------------------------------
8 License
9     This file is part of OpenFOAM.
11     OpenFOAM 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 2 of the License, or (at your
14     option) any later version.
16     OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18     FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
19     for more details.
21     You should have received a copy of the GNU General Public License
22     along with OpenFOAM; if not, write to the Free Software Foundation,
23     Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
25 Description
26     Searches the current case directory for valid times
27     and sets the time list to these.
28     This is done if a times File does not exist.
30 \*---------------------------------------------------------------------------*/
32 #include "Time.H"
33 #include "OSspecific.H"
34 #include "IStringStream.H"
36 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
38 Foam::instantList Foam::Time::findTimes(const fileName& directory)
40     if (debug)
41     {
42         Info<< "Time::findTimes(const fileName&): finding times in directory "
43             << directory << endl;
44     }
46     // Read directory entries into a list
47     fileNameList dirEntries(readDir(directory, fileName::DIRECTORY));
49     // Initialise instant list
50     instantList Times(dirEntries.size() + 1);
51     label nTimes = 0;
53     // Check for "constant"
54     bool haveConstant = false;
55     forAll(dirEntries, i)
56     {
57         if (dirEntries[i] == "constant")
58         {
59             Times[nTimes].value() = 0;
60             Times[nTimes].name() = dirEntries[i];
61             nTimes++;
62             haveConstant = true;
63             break;
64         }
65     }
67     // Read and parse all the entries in the directory
68     forAll(dirEntries, i)
69     {
70         IStringStream timeStream(dirEntries[i]);
71         token timeToken(timeStream);
73         if (timeToken.isNumber() && timeStream.eof())
74         {
75             Times[nTimes].value() = timeToken.number();
76             Times[nTimes].name() = dirEntries[i];
77             nTimes++;
78         }
79     }
81     // Reset the length of the times list
82     Times.setSize(nTimes);
84     if (haveConstant)
85     {
86         if (nTimes > 2)
87         {
88             std::sort(&Times[1], Times.end(), instant::less());
89         }
90     }
91     else if (nTimes > 1)
92     {
93         std::sort(&Times[0], Times.end(), instant::less());
94     }
96     return Times;
99 // ************************************************************************* //