26#include "ioexnl_export.h"
43 class StructuredBlock;
45 class ElementTopology;
50 class PropertyManager;
54 struct CommunicationMetaData;
71 void get_step_times_nl()
override;
73 bool handle_output_file(
bool write_message, std::string *error_msg,
int *bad_count,
74 bool overwrite,
bool abort_if_error)
const override;
75 bool check_valid_file_ptr(
bool write_message, std::string *error_msg,
int *bad_count,
76 bool abort_if_error)
const;
79 size_t data_size)
const override;
81 size_t data_size)
const override;
83 size_t data_size)
const override;
85 size_t data_size)
const override;
87 size_t data_size)
const override;
89 size_t data_size)
const override;
91 size_t data_size)
const override;
93 size_t data_size)
const override;
95 size_t data_size)
const override;
97 size_t data_size)
const override;
99 size_t data_size)
const override;
101 size_t data_size)
const override;
103 size_t data_size)
const override;
105 size_t data_size)
const override;
109 size_t )
const override
114 size_t data_size)
const;
116 size_t data_size)
const;
124 void read_meta_data_nl()
override;
138 std::vector<int> &is_valid_side)
const;
142 int64_t count,
void *variables)
const;
145 int64_t count,
void *variables)
const;
154 void get_blocks(ex_entity_type entity_type,
int rank_offset,
const std::string &basename);
158 template <
typename T>
159 void get_sets(ex_entity_type type, int64_t count,
const std::string &base,
171 ex_entity_type entity_type,
172 ex_inquiry inquiry_type)
const;
175 int64_t handle_node_ids(
void *ids, int64_t num_to_get)
const;
176 int64_t handle_element_ids(
const Ioss::ElementBlock *eb,
void *ids,
size_t num_to_get)
const;
177 int64_t handle_face_ids(
const Ioss::FaceBlock *eb,
void *ids,
size_t num_to_get)
const;
178 int64_t handle_edge_ids(
const Ioss::EdgeBlock *eb,
void *ids,
size_t num_to_get)
const;
181 void *fconnect,
bool map_ids)
const;
182 template <
typename INT>
184 int64_t side_count, INT *fconnect,
bool map_ids)
const;
186 double *dist_fact,
size_t data_size)
const;
189 size_t data_size)
const;
191 size_t data_size)
const;
194 mutable bool isSerialParallel{
false};
#define IOSS_NODISCARD
Definition Ioss_CodeTypes.h:55
int Ioss_MPI_Comm
Definition Ioss_CodeTypes.h:64
Definition Ioexnl_BaseDatabaseIO.h:78
Definition Ioexnl_DatabaseIO.h:62
void get_blocks(ex_entity_type entity_type, int rank_offset, const std::string &basename)
int64_t get_side_distributions(const Ioss::SideBlock *sd_blk, int64_t id, int64_t my_side_count, double *dist_fact, size_t data_size) const
int64_t read_attribute_field(const Ioss::Field &field, const Ioss::GroupingEntity *ge, void *data) const
void get_sets(ex_entity_type type, int64_t count, const std::string &base, const T *)
IOSS_NODISCARD const Ioss::Map & get_map(ex_entity_type type) const
int64_t get_side_field(const Ioss::SideBlock *sd_blk, const Ioss::Field &field, void *data, size_t data_size) const
void read_communication_metadata()
IOSS_NODISCARD const Ioss::Map & get_map(Ioss::Map &entity_map, int64_t entity_count, ex_entity_type entity_type, ex_inquiry inquiry_type) const
int64_t read_ss_transient_field(const Ioss::Field &field, int64_t id, void *variables, std::vector< int > &is_valid_side) const
int64_t get_side_connectivity(const Ioss::SideBlock *sd_blk, int64_t id, int64_t my_side_count, void *fconnect, bool map_ids) const
int64_t put_side_field(const Ioss::SideBlock *sd_blk, const Ioss::Field &field, void *data, size_t data_size) const
true if application code is controlling the processor id.
int64_t read_nodal_coordinates()
void read_elements(const Ioss::ElementBlock &block)
void compute_node_status() const
int64_t read_transient_field(const Ioexnl::VariableNameMap &variables, const Ioss::Field &field, const Ioss::GroupingEntity *ge, void *data) const
int64_t put_field_internal(const Ioss::StructuredBlock *, const Ioss::Field &, void *, size_t) const override
Definition Ioexnl_DatabaseIO.h:107
int64_t get_Xset_field_internal(const Ioss::EntitySet *ns, const Ioss::Field &field, void *data, size_t data_size) const
int64_t get_side_connectivity_internal(const Ioss::SideBlock *sd_blk, int64_t id, int64_t side_count, INT *fconnect, bool map_ids) const
A homogeneous collection of other GroupingEntities.
Definition Ioss_Assembly.h:31
A homogeneous collection of other GroupingEntities.
Definition Ioss_Blob.h:31
Definition Ioss_CommSet.h:27
A collection of element edges with the same topology.
Definition Ioss_EdgeBlock.h:29
A collection of element edges.
Definition Ioss_EdgeSet.h:30
A collection of elements having the same topology.
Definition Ioss_ElementBlock.h:29
A collection of elements.
Definition Ioss_ElementSet.h:30
Base class for all 'set'-type grouping entities, which means that members of the set are not necessar...
Definition Ioss_EntitySet.h:38
A collection of element faces with the same topology.
Definition Ioss_FaceBlock.h:29
A collection of element faces.
Definition Ioss_FaceSet.h:30
Holds metadata for bulk data associated with a GroupingEntity.
Definition Ioss_Field.h:25
Base class for all 'grouping' entities. The following derived classes are typical:
Definition Ioss_GroupingEntity.h:67
A collection of all nodes in the region.
Definition Ioss_NodeBlock.h:33
A collection of nodes.
Definition Ioss_NodeSet.h:29
A collection of Ioss::Property objects.
Definition Ioss_PropertyManager.h:36
A grouping entity that contains other grouping entities.
Definition Ioss_Region.h:93
A collection of element sides having the same topology.
Definition Ioss_SideBlock.h:37
A collection of element sides.
Definition Ioss_SideSet.h:29
A structured zone – i,j,k.
Definition Ioss_StructuredBlock.h:91
A namespace for the exodus database format.
Definition Ioexnl_BaseDatabaseIO.C:93
std::map< std::string, int, std::less<> > VariableNameMap
Definition Ioexnl_BaseDatabaseIO.h:61
The main namespace for the Ioss library.
Definition Ioad_DatabaseIO.C:40
DatabaseUsage
Specifies how an Ioss::DatabaseIO object will be used.
Definition Ioss_DBUsage.h:13
IfDatabaseExistsBehavior
Definition Ioss_DBUsage.h:32