Go to the documentation of this file.
94 static bool hasReadWriteTypes(
const word& readType,
const word& writeType)
96 volatile bool good =
true;
114 int main(
int argc,
char *argv[])
118 "Convert between surface formats, using MeshSurface library components"
128 "Perform some surface checking/cleanup on the input surface"
134 "Input format (default: use file extension)"
140 "Output format (default: use file extension)"
146 "Input geometry scaling factor"
152 "Output geometry scaling factor"
164 "The source coordinate system, applied after '-read-scale'",
171 "The target coordinate system, applied before '-write-scale'",
177 "Triangulate surface"
187 if (importName == exportName)
190 <<
"Output file would overwrite input file."
194 const word readFileType
199 const word writeFileType
206 if (!hasReadWriteTypes(readFileType, writeFileType))
209 <<
"Unsupported file format(s)" <<
nl
214 scalar scaleFactor(0);
226 coordinateSystems::typeName,
239 <<
"Cannot open coordinateSystems file\n "
249 const auto* csPtr = globalCoords.cfind(csName);
254 <<
"Cannot find -from " << csName <<
nl
255 <<
"available coordinateSystems: "
266 const auto* csPtr = globalCoords.cfind(csName);
271 <<
"Cannot find -to " << csName <<
nl
272 <<
"available coordinateSystems: "
281 if (fromCsys && toCsys)
284 <<
"Only allowed '-from' or '-to' option at the moment."
295 Info<<
"scale input " << scaleFactor <<
nl;
296 surf.scalePoints(scaleFactor);
306 Info<<
"move points from coordinate system: "
307 << fromCsys->name() <<
nl;
309 surf.movePoints(tpf());
314 Info<<
"move points to coordinate system: "
315 << toCsys->name() <<
nl;
317 surf.movePoints(tpf());
322 Info<<
"scale output " << scaleFactor <<
nl;
323 surf.scalePoints(scaleFactor);
328 Info<<
"triangulate" <<
nl;
332 Info<<
"writing " << exportName;
333 surf.write(exportName, writeFileType);
static autoPtr< T > New(Args &&... args)
Defines the attributes of an object for which implicit objectRegistry management is supported,...
Class to control time during OpenFOAM simulations that is also the top-level objectRegistry.
A class for handling words, derived from Foam::string.
A class for handling file names.
T getOrDefault(const word &optName, const T &deflt) const
static bool canReadType(const word &fileType, bool verbose=false)
A class for managing temporary objects.
bool typeHeaderOk(const bool checkType=true, const bool search=true, const bool verbose=true)
const fileName & caseName() const noexcept
static void addNote(const string ¬e)
static void addOptionCompat(const word &optName, std::pair< const char *, int > compat)
Extract command arguments and options from the supplied argc and argv parameters.
Ostream & endl(Ostream &os)
static bool canWriteType(const word &fileType, bool verbose=false)
T get(const label index) const
bool readIfPresent(const word &optName, T &val) const
static void addArgument(const string &argName, const string &usage="")
static IOobject selectIO(const IOobject &io, const fileName &altFile, const word &ioName="")
A centralized collection of named coordinate systems.
FlatOutput::OutputAdaptor< Container, Delimiters > flatOutput(const Container &obj, Delimiters delim)
errorManipArg< error, int > exit(error &err, const int errNo=1)
static void addBoolOption(const word &optName, const string &usage="", bool advanced=false)
Pointer management similar to std::unique_ptr, with some additional methods and type checking.
word name(const expressions::valueTypeCode typeCode)
fileName objectPath() const
const word & constant() const
A surface geometry mesh with zone information, not to be confused with the similarly named surfaceMes...
static void addOption(const word &optName, const string ¶m="", const string &usage="", bool advanced=false)
Foam::argList args(argc, argv)
const fileName & rootPath() const noexcept
bool found(const word &optName) const