ENH: autoLayerDriver: better layering information message
[OpenFOAM-2.0.x.git] / src / OpenFOAM / global / argList / parRun.H
blob724c166cf01fd12af413b03a0c93941853ced41a
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2011 OpenFOAM Foundation
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
13     the Free Software Foundation, either version 3 of the License, or
14     (at your 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, see <http://www.gnu.org/licenses/>.
24 Class
25     Foam::ParRunControl
27 Description
28     Helper class for initializing parallel jobs from the command arguments.
30 \*---------------------------------------------------------------------------*/
32 #ifndef parRun_H
33 #define parRun_H
35 #include "Pstream.H"
36 #include "IOstreams.H"
38 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
40 namespace Foam
43 /*---------------------------------------------------------------------------*\
44                            Class ParRunControl Declaration
45 \*---------------------------------------------------------------------------*/
47 class ParRunControl
49     bool RunPar;
51 public:
53     ParRunControl()
54     :
55         RunPar(false)
56     {}
58     ~ParRunControl()
59     {
60         if (RunPar)
61         {
62             Info<< "Finalising parallel run" << endl;
63             Pstream::exit(0);
64         }
65     }
67     void runPar(int& argc, char**& argv)
68     {
69         RunPar = true;
71         if (!Pstream::init(argc, argv))
72         {
73             Info<< "Failed to start parallel run" << endl;
74             Pstream::exit(1);
75         }
76     }
78     bool parRun() const
79     {
80         return RunPar;
81     }
85 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
87 } // End namespace Foam
89 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
91 #endif
93 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //