1 // Copyright(C) 1999-2020 National Technology & Engineering Solutions
2 // of Sandia, LLC (NTESS).  Under the terms of Contract DE-NA0003525 with
3 // NTESS, the U.S. Government retains certain rights in this software.
4 //
5 // See packages/seacas/LICENSE for details
6 
7 #include <Ioss_CodeTypes.h> // for IntVector
8 #include <Ioss_DatabaseIO.h>
9 #include <Ioss_EdgeBlock.h>
10 #include <Ioss_ElementTopology.h>
11 #include <Ioss_Property.h>
12 #include <cstddef>
13 #include <string>
14 
15 #include "Ioss_EntityBlock.h"
16 #include "Ioss_PropertyManager.h"
17 
18 namespace Ioss {
19   class Field;
20 } // namespace Ioss
21 
22 /** \brief Create an edge block.
23  *
24  *  \param[in] io_database The database associated with the region containing the edge block.
25  *  \param[in] my_name The edge block's name.
26  *  \param[in] edge_type The name of the edge topology type for the edge block.
27  *  \param[in] number_edges The number of edges in the edge block.
28  */
EdgeBlock(Ioss::DatabaseIO * io_database,const std::string & my_name,const std::string & edge_type,int64_t number_edges)29 Ioss::EdgeBlock::EdgeBlock(Ioss::DatabaseIO *io_database, const std::string &my_name,
30                            const std::string &edge_type, int64_t number_edges)
31     : Ioss::EntityBlock(io_database, my_name, edge_type, number_edges)
32 {
33   if (topology()->master_element_name() != edge_type && topology()->name() != edge_type) {
34     // Maintain original edge type on output database if possible.
35     properties.add(Ioss::Property("original_edge_type", edge_type));
36   }
37 }
38 
39 Ioss::EdgeBlock::~EdgeBlock() = default;
40 
get_implicit_property(const std::string & my_name)41 Ioss::Property Ioss::EdgeBlock::get_implicit_property(const std::string &my_name) const
42 {
43   return Ioss::EntityBlock::get_implicit_property(my_name);
44 }
45 
internal_get_field_data(const Ioss::Field & field,void * data,size_t data_size)46 int64_t Ioss::EdgeBlock::internal_get_field_data(const Ioss::Field &field, void *data,
47                                                  size_t data_size) const
48 {
49   return get_database()->get_field(this, field, data, data_size);
50 }
51 
internal_put_field_data(const Ioss::Field & field,void * data,size_t data_size)52 int64_t Ioss::EdgeBlock::internal_put_field_data(const Ioss::Field &field, void *data,
53                                                  size_t data_size) const
54 {
55   return get_database()->put_field(this, field, data, data_size);
56 }
57