fileOperationInitialise.C
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration |
5  \\ / A nd | www.openfoam.com
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8  Copyright (C) 2017-2018 OpenFOAM Foundation
9  Copyright (C) 2019-2021 OpenCFD Ltd.
10 -------------------------------------------------------------------------------
11 License
12  This file is part of OpenFOAM.
13 
14  OpenFOAM is free software: you can redistribute it and/or modify it
15  under the terms of the GNU General Public License as published by
16  the Free Software Foundation, either version 3 of the License, or
17  (at your option) any later version.
18 
19  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
20  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
22  for more details.
23 
24  You should have received a copy of the GNU General Public License
25  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
26 
27 \*---------------------------------------------------------------------------*/
28 
30 #include "OSspecific.H"
32 
33 /* * * * * * * * * * * * * * * Static Member Data * * * * * * * * * * * * * */
34 
35 namespace Foam
36 {
37 namespace fileOperations
38 {
41 }
42 }
43 
44 
45 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
46 
48 (
49  int& argc,
50  char**& argv
51 )
52 {
53  // Filter out commonly known arguments
54  const string s("-ioRanks");
55 
56  int index = -1;
57  for (int i=1; i<argc-1; i++)
58  {
59  if (argv[i] == s)
60  {
61  index = i;
62  Foam::setEnv("FOAM_IORANKS", argv[i+1], true);
63  break;
64  }
65  }
66 
67  if (index > 0)
68  {
69  for (int i=index+2; i<argc; i++)
70  {
71  argv[i-2] = argv[i];
72  }
73  argc -= 2;
74  }
75 }
76 
77 
80 (
81  const word& type,
82  int& argc,
83  char**& argv
84 )
85 {
86  DebugInFunction << "Constructing fileOperationInitialise" << endl;
87 
88  auto* ctorPtr = wordConstructorTable(type);
89 
90  if (!ctorPtr)
91  {
93  (
94  "fileOperationInitialise",
95  type,
96  *wordConstructorTablePtr_
97  ) << abort(FatalError);
98  }
99 
100  return autoPtr<fileOperationInitialise>(ctorPtr(argc, argv));
101 }
102 
103 
104 // ************************************************************************* //
OSspecific.H
Functions used by OpenFOAM that are specific to POSIX compliant operating systems and need to be repl...
Foam::word
A class for handling words, derived from Foam::string.
Definition: word.H:65
s
gmvFile<< "tracers "<< particles.size()<< nl;for(const passiveParticle &p :particles){ gmvFile<< p.position().x()<< " ";}gmvFile<< nl;for(const passiveParticle &p :particles){ gmvFile<< p.position().y()<< " ";}gmvFile<< nl;for(const passiveParticle &p :particles){ gmvFile<< p.position().z()<< " ";}gmvFile<< nl;forAll(lagrangianScalarNames, i){ word name=lagrangianScalarNames[i];IOField< scalar > s(IOobject(name, runTime.timeName(), cloud::prefix, mesh, IOobject::MUST_READ, IOobject::NO_WRITE))
Definition: gmvOutputSpray.H:25
fileOperationInitialise.H
Foam::endl
Ostream & endl(Ostream &os)
Add newline and flush stream.
Definition: Ostream.H:369
Foam::setEnv
bool setEnv(const word &name, const std::string &value, const bool overwrite)
Set an environment variable, return true on success.
Definition: MSwindows.C:395
DebugInFunction
#define DebugInFunction
Report an information message using Foam::Info.
Definition: messageStream.H:388
Foam::FatalError
error FatalError
FatalErrorInLookup
#define FatalErrorInLookup(lookupTag, lookupName, lookupTable)
Report an error message using Foam::FatalError.
Definition: error.H:457
addToRunTimeSelectionTable.H
Macros for easy insertion into run-time selection tables.
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
Foam::abort
errorManip< error > abort(error &err)
Definition: errorManip.H:144
fileOperationInitialise
General fileOperation initialiser. Handles -ioRanks option, using it to set the FOAM_IORANKS environm...
Foam::autoPtr
Pointer management similar to std::unique_ptr, with some additional methods and type checking.
Definition: HashPtrTable.H:53
Foam::fileOperations::defineRunTimeSelectionTable
defineRunTimeSelectionTable(fileOperationInitialise, word)
Foam::roots::type
type
Types of root.
Definition: Roots.H:54
Foam::fileOperations::defineTypeNameAndDebug
defineTypeNameAndDebug(collatedFileOperation, 0)
Foam::fileOperations::fileOperationInitialise::fileOperationInitialise
fileOperationInitialise(int &argc, char **&argv)
Construct from components.
Definition: fileOperationInitialise.C:48
Foam::fileOperations::fileOperationInitialise::New
static autoPtr< fileOperationInitialise > New(const word &type, int &argc, char **&argv)
Select type.
Definition: fileOperationInitialise.C:80