// Copyright (C) 2007-2024 CEA, EDF, OPEN CASCADE // // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 2.1 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // // File : NETGENplugin_Runnner_main.cxx // Author : Yoann AUDOUIN, EDF // Module : NETGEN // #include "NETGENPlugin_NETGEN_2D_SA.hxx" #include "NETGENPlugin_NETGEN_3D_SA.hxx" #include "NETGENPlugin_NETGEN_1D2D3D_SA.hxx" #include #include #include #include /** * @brief Main function * * @param argc Number of arguments * @param argv Arguments * * @return error code */ int main(int argc, char *argv[]){ if(argc!=8||(argc==2 && (strcmp(argv[1], "-h") == 0 || strcmp(argv[1], "--help")==0))){ std::cout << "Error in number of arguments "<< argc-1<<" given expected 7" <> thing; if (output_mesh_file == "NONE") output_mesh_file = ""; if (element_orientation_file == "NONE") element_orientation_file = ""; if (new_element_file == "NONE") new_element_file = ""; int ret = 0; if (mesher=="NETGEN3D"){ NETGENPlugin_NETGEN_3D_SA myplugin; ret = myplugin.run(input_mesh_file, shape_file, hypo_file, element_orientation_file, new_element_file, output_mesh_file ); } else if ( mesher=="NETGEN1D" || mesher=="NETGEN1D2D" || mesher=="NETGEN1D2D3D" ) { NETGENPlugin_NETGEN_1D2D3D_SA myplugin; NETGENPlugin_Mesher::DIM DIM = mesher=="NETGEN1D" ? NETGENPlugin_Mesher::D1 : ( mesher=="NETGEN1D2D" ? NETGENPlugin_Mesher::D2 : NETGENPlugin_Mesher::D3 ); ret = myplugin.run(input_mesh_file, shape_file, hypo_file, element_orientation_file, new_element_file, output_mesh_file, DIM ); } else if ( mesher=="NETGEN2D" ) { NETGENPlugin_NETGEN_2D_SA myplugin; ret = myplugin.run(input_mesh_file, shape_file, hypo_file, element_orientation_file, new_element_file, output_mesh_file ); } else { std::cerr << "Unknown mesher:" << mesher << std::endl; return 1; } return ret; }