Cloned SEACAS for EXODUS library with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

78 lines
2.4 KiB

2 years ago
/*
* Copyright(C) 1999-2020, 2022 National Technology & Engineering Solutions
* of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with
* NTESS, the U.S. Government retains certain rights in this software.
*
* See packages/seacas/LICENSE for details
*/
#pragma once
#include "EP_ObjectType.h"
#include <cstring>
#include <smart_assert.h>
#include <string>
#include <vector>
namespace Excn {
enum class InOut { IN = 1, OUT = 2 };
using IntVector = std::vector<int>;
struct Variables
{
explicit Variables(ObjectType otype) : objectType(otype), outputCount(0), addProcessorId(false)
{
SMART_ASSERT(otype == Excn::ObjectType::EBLK || otype == Excn::ObjectType::NSET ||
otype == Excn::ObjectType::SSET || otype == Excn::ObjectType::NODE ||
otype == Excn::ObjectType::EDBLK || otype == Excn::ObjectType::FABLK ||
otype == Excn::ObjectType::GLOBAL);
}
int count(InOut in_out = InOut::IN) const
{
int ret_val = 0;
switch (in_out) {
case InOut::IN: ret_val = index_.size() - (addProcessorId ? 1 : 0); break;
case InOut::OUT: ret_val = outputCount; break;
}
return ret_val;
}
const char *label() const
{
switch (objectType) {
case Excn::ObjectType::EBLK: return "element";
case Excn::ObjectType::NSET: return "nodeset";
case Excn::ObjectType::GLOBAL: return "global";
case Excn::ObjectType::NODE: return "nodal";
case Excn::ObjectType::SSET: return "sideset";
case Excn::ObjectType::EDBLK: return "edgeblock";
case Excn::ObjectType::FABLK: return "faceblock";
default: return "UNKNOWN";
}
}
ex_entity_type type() const
{
switch (objectType) {
case Excn::ObjectType::EBLK: return EX_ELEM_BLOCK;
case Excn::ObjectType::NSET: return EX_NODE_SET;
case Excn::ObjectType::SSET: return EX_SIDE_SET;
case Excn::ObjectType::NODE: return EX_NODAL;
case Excn::ObjectType::GLOBAL: return EX_GLOBAL;
case Excn::ObjectType::EDBLK: return EX_EDGE_BLOCK;
case Excn::ObjectType::FABLK: return EX_FACE_BLOCK;
default: return EX_INVALID;
}
}
bool add_processor_id() const { return addProcessorId; }
ObjectType objectType;
int outputCount;
bool addProcessorId;
IntVector index_{};
std::string type_{};
};
} // namespace Excn