NEMoSys  0.63.0
A modular, extensible resource with robust automated mesh generation, mesh quality analysis, adaptive mesh refinement, and data transfer between arbitrary meshes.
rocPackShape.C
Go to the documentation of this file.
1 /*******************************************************************************
2 * Promesh *
3 * Copyright (C) 2022, IllinoisRocstar LLC. All rights reserved. *
4 * *
5 * Promesh is the property of IllinoisRocstar LLC. *
6 * *
7 * IllinoisRocstar LLC *
8 * Champaign, IL *
9 * www.illinoisrocstar.com *
10 * promesh@illinoisrocstar.com *
11 *******************************************************************************/
12 /*******************************************************************************
13 * This file is part of Promesh *
14 * *
15 * This version of Promesh is free software: you can redistribute it and/or *
16 * modify it under the terms of the GNU Lesser General Public License as *
17 * published by the Free Software Foundation, either version 3 of the License, *
18 * or (at your option) any later version. *
19 * *
20 * Promesh is distributed in the hope that it will be useful, but WITHOUT ANY *
21 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS *
22 * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more *
23 * details. *
24 * *
25 * You should have received a copy of the GNU Lesser General Public License *
26 * along with this program. If not, see <https://www.gnu.org/licenses/>. *
27 * *
28 *******************************************************************************/
29 #include "Geometry/hmxShape.H"
31 #include "Geometry/petnShape.H"
32 #include "Geometry/rocPackShape.H"
33 
34 namespace NEM {
35 
36 namespace GEO {
37 
38 std::shared_ptr<rocPackShape> rocPackShape::getShape(
39  const std::string &shapeName) {
40  if (shapeName == "hmx") {
41  std::shared_ptr<hmxShape> assignShape(new hmxShape());
42  return assignShape;
43  } else if (shapeName == "petn") {
44  std::shared_ptr<petnShape> assignShape(new petnShape());
45  return assignShape;
46  } else if (shapeName == "icosidodecahedron") {
47  std::shared_ptr<icosidodecahedronShape> assignShape(
49  return assignShape;
50  } else {
51  std::cerr << "The " << shapeName << " shape is not supported yet!"
52  << std::endl;
53  throw;
54  }
55 }
56 
57 } // namespace GEO
58 
59 } // namespace NEM
This class wraps around abstract class rocPackShape.
Definition: petnShape.H:46
This class wraps around abstract class rocPackShape.
static std::shared_ptr< rocPackShape > getShape(const std::string &shapeName)
Creates shape object for requsted shape.
Definition: rocPackShape.C:38
This class wraps around abstract class rocPackShape.
Definition: hmxShape.H:45