GRINS-0.8.0
dirichlet_bc_factory_abstract.C
Go to the documentation of this file.
1 //-----------------------------------------------------------------------bl-
2 //--------------------------------------------------------------------------
3 //
4 // GRINS - General Reacting Incompressible Navier-Stokes
5 //
6 // Copyright (C) 2014-2017 Paul T. Bauman, Roy H. Stogner
7 // Copyright (C) 2010-2013 The PECOS Development Team
8 //
9 // This library is free software; you can redistribute it and/or
10 // modify it under the terms of the Version 2.1 GNU Lesser General
11 // Public License as published by the Free Software Foundation.
12 //
13 // This library is distributed in the hope that it will be useful,
14 // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 // Lesser General Public License for more details.
17 //
18 // You should have received a copy of the GNU Lesser General Public
19 // License along with this library; if not, write to the Free Software
20 // Foundation, Inc. 51 Franklin Street, Fifth Floor,
21 // Boston, MA 02110-1301 USA
22 //
23 //-----------------------------------------------------------------------el-
24 
25 // This class
27 
28 namespace GRINS
29 {
30  // Full specialization for the Factory<DirichletBoundary>
31  template<>
32  std::map<std::string, FactoryAbstract<libMesh::DirichletBoundary>*>&
34  {
35  static std::map<std::string, FactoryAbstract<libMesh::DirichletBoundary>*> _map;
36  return _map;
37  }
38 
39  // Definition of static members
40  template<>
42 
43  template<>
45 
46  template<>
47  const std::set<BoundaryID>* BCFactoryAbstract<libMesh::DirichletBoundary>::_bc_ids = NULL;
48 
49  template<>
51 
52  template<>
54 
55  void DirichletBCFactoryAbstract::check_for_vars( const GetPot& input, const std::string& section,
56  const std::vector<std::string>& var_names,
57  std::set<std::string>* vars_found )
58  {
59  if( vars_found )
60  vars_found->clear();
61 
62  bool found_var = false;
63 
64  for( std::vector<std::string>::const_iterator name = var_names.begin();
65  name < var_names.end(); ++name )
66  {
67  if( input.have_variable( section+"/"+(*name) ) )
68  {
69  found_var = true;
70 
71  if( vars_found )
72  vars_found->insert( (*name) );
73  }
74  }
75 
76  // If no variables were found to be set, error out printing
77  // the section and the variable names we were looking for.
78  if( !found_var )
79  {
80  std::string err_msg = "ERROR: Could find any active variable assigned a Dirichlet boundary value\n";
81  err_msg += " in section "+section+". Active variables are:\n";
82 
83  for( std::vector<std::string>::const_iterator name = var_names.begin();
84  name < var_names.end(); ++name )
85  err_msg += " "+(*name)+"\n";
86 
87  libmesh_error_msg(err_msg);
88  }
89 
90  if( vars_found )
91  libmesh_assert(!vars_found->empty());
92  }
93 
94 } // end namespace GRINS
static std::map< std::string, FactoryAbstract< Base > * > & factory_map()
GRINS namespace.
Interface with libMesh for solving Multiphysics problems.
Abstract factory that provides availability of GetPot.

Generated on Tue Dec 19 2017 12:47:27 for GRINS-0.8.0 by  doxygen 1.8.9.1