X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/31a461643fe82c00e0fe4efc8941eee20b0838ea..41c54c2772412935a5c8fc9f2d09e623c0383ae7:/src/mc/Type.hpp diff --git a/src/mc/Type.hpp b/src/mc/Type.hpp index 287a6794b9..819cf81b6e 100644 --- a/src/mc/Type.hpp +++ b/src/mc/Type.hpp @@ -10,39 +10,28 @@ #include #include -#include "mc_forward.h" -#include "mc_location.h" +#include + +#include "src/mc/mc_forward.h" +#include "src/mc/LocationList.hpp" namespace simgrid { namespace mc { -/** Represents a type in the program +/** A member of a structure, union * - * It is currently used to represent members of structs and unions as well. + * Inheritance is seen as a special member as well. */ -class Type { +class Member { public: - Type(); - Type(Type const& type) = default; - Type& operator=(Type const&) = default; - Type(Type&& type) = default; - Type& operator=(Type&&) = default; + Member() : inheritance(false), byte_size(0), type_id(0) {} - /** The DWARF TAG of the type (e.g. DW_TAG_array_type) */ - int type; - unsigned id; /* Offset in the section (in hexadecimal form) */ - std::string name; /* Name of the type */ - int byte_size; /* Size in bytes */ - int element_count; /* Number of elements for array type */ - unsigned type_id; /* DW_AT_type id */ - std::vector members; /* if DW_TAG_structure_type, DW_TAG_class_type, DW_TAG_union_type*/ - int is_pointer_type; - - // Location (for members) is either of: - simgrid::mc::DwarfExpression location_expression; - - simgrid::mc::Type* subtype; // DW_AT_type - simgrid::mc::Type* full_type; // The same (but more complete) type + bool inheritance; + std::string name; + simgrid::dwarf::DwarfExpression location_expression; + std::size_t byte_size; // Do we really need this? + unsigned type_id; + simgrid::mc::Type* type; bool has_offset_location() const { @@ -66,6 +55,42 @@ public: } }; +/** A type in the model-checked program */ +class Type { +public: + Type(); + Type(Type const& type) = default; + Type& operator=(Type const&) = default; + Type(Type&& type) = default; + Type& operator=(Type&&) = default; + + /** The DWARF TAG of the type (e.g. DW_TAG_array_type) */ + int type; + unsigned id; /* Offset in the section (in hexadecimal form) */ + std::string name; /* Name of the type */ + int byte_size; /* Size in bytes */ + int element_count; /* Number of elements for array type */ + unsigned type_id; /* DW_AT_type id */ + std::vector members; /* if DW_TAG_structure_type, DW_TAG_class_type, DW_TAG_union_type*/ + int is_pointer_type; + + simgrid::mc::Type* subtype; // DW_AT_type + simgrid::mc::Type* full_type; // The same (but more complete) type +}; + +inline +Type::Type() +{ + this->type = 0; + this->id = 0; + this->byte_size = 0; + this->element_count = 0; + this->is_pointer_type = 0; + this->type_id = 0; + this->subtype = nullptr; + this->full_type = nullptr; +} + } }