A Datatype is a Datatype_template that accepts no argument. More...
 
  
| Public Member Functions | |
| Datatype (const Attributes_map &attributes={}) | |
| Creates a new datatype.  More... | |
| ~Datatype () override | |
| virtual bool | operator== (const Datatype &other) const =0 | 
| Test for equality.  More... | |
| bool | operator!= (const Datatype &other) const | 
| Test for inequality.  More... | |
| virtual Datatype_sptr | densify () const =0 | 
| Creates a new datatype as the dense copy of this one.  More... | |
| virtual bool | dense () const =0 | 
| Indicate if the datatype is dense or not.  More... | |
| virtual size_t | datasize () const =0 | 
| Computes the data size of a type, excluding potentially unused memory from a sparse type.  More... | |
| virtual size_t | buffersize () const =0 | 
| Computes the data size of a type, including potentially unused memory from a sparse type.  More... | |
| virtual size_t | alignment () const =0 | 
| Returns the required alignment for a type.  More... | |
| virtual bool | simple () const =0 | 
| Tells if data can be copied as bytes (if type is dense) and doesn't need a destroyer.  More... | |
| virtual void * | data_to_dense_copy (void *to, const void *from) const =0 | 
| Creates a dense deep copy of data.  More... | |
| virtual void * | data_from_dense_copy (void *to, const void *from) const =0 | 
| Creates a sparse deep copy of dense data.  More... | |
| virtual Datatype_sptr | index (size_t index) const | 
| Access the type of the element at the provided index.  More... | |
| virtual std::pair< void *, Datatype_sptr > | index (size_t index, void *data) const | 
| Access the type and value of the element at the provided index.  More... | |
| virtual Datatype_sptr | slice (size_t start_index, size_t end_index) const | 
| Access the type of the elements slice between the provided indices.  More... | |
| virtual std::pair< void *, Datatype_sptr > | slice (size_t start_index, size_t end_index, void *data) const | 
| Access the type and value of the elements slice between the provided indices.  More... | |
| virtual Datatype_sptr | member (const char *name) const | 
| Access the type of the member with the provided name.  More... | |
| virtual std::pair< void *, Datatype_sptr > | member (const char *name, void *data) const | 
| Access the type and value of the member with the provided name.  More... | |
| virtual Datatype_sptr | dereference () const | 
| Access the type referenced by this.  More... | |
| virtual std::pair< void *, Datatype_sptr > | dereference (void *data) const | 
| Access the type and value referenced by this.  More... | |
| virtual void | destroy_data (void *ptr) const =0 | 
| Delete data whose type is described by the Datatype.  More... | |
| virtual std::string | debug_string () const =0 | 
| Returns the datatype yaml representation as a string.  More... | |
|  Public Member Functions inherited from PDI::Datatype_template | |
| Datatype_template (const Attributes_map &attributes={}) | |
| Creates datatype template with given attributes.  More... | |
| Datatype_template (PC_tree_t datatype_tree) | |
| Creates datatype template.  More... | |
| virtual | ~Datatype_template () | 
| Destroys the template.  More... | |
| virtual Datatype_sptr | evaluate (Context &ctx) const =0 | 
| Creates a new datatype by resolving the value of all metadata references.  More... | |
| Expression | attribute (const std::string &attribute_name) const | 
| Returns attribute of given name as Expression.  More... | |
| const Attributes_map & | attributes () const | 
| Returns all attributes as a unordered map.  More... | |
| Additional Inherited Members | |
|  Static Public Member Functions inherited from PDI::Datatype_template | |
| static void | load_basic_datatypes (Context &ctx) | 
| Adds to the context the basic Array, Record, C and Fortran datatypes.  More... | |
| static void | load_user_datatypes (Context &ctx, PC_tree_t types_tree) | 
| Adds to the context the user defined datatypes.  More... | |
|  Protected Attributes inherited from PDI::Datatype_template | |
| Attributes_map | m_attributes | 
A Datatype is a Datatype_template that accepts no argument.
It represents the memory layout of data and supports some simple operations on it:
| PDI::Datatype::Datatype | ( | const Attributes_map & | attributes = {} | ) | 
Creates a new datatype.
| [in] | attributes | attributes of the datatype | 
| 
 | override | 
| 
 | pure virtual | 
Test for equality.
| other | the Datatype to compare | 
Implemented in PDI::Array_datatype, PDI::Pointer_datatype, PDI::Record_datatype, PDI::Scalar_datatype, and PDI::Tuple_datatype.
| bool PDI::Datatype::operator!= | ( | const Datatype & | other | ) | const | 
| 
 | pure virtual | 
Creates a new datatype as the dense copy of this one.
Implemented in PDI::Array_datatype, PDI::Pointer_datatype, PDI::Record_datatype, PDI::Scalar_datatype, and PDI::Tuple_datatype.
| 
 | pure virtual | 
Indicate if the datatype is dense or not.
Implemented in PDI::Array_datatype, PDI::Pointer_datatype, PDI::Record_datatype, PDI::Scalar_datatype, and PDI::Tuple_datatype.
| 
 | pure virtual | 
Computes the data size of a type, excluding potentially unused memory from a sparse type.
Implemented in PDI::Array_datatype, PDI::Pointer_datatype, PDI::Record_datatype, PDI::Scalar_datatype, and PDI::Tuple_datatype.
| 
 | pure virtual | 
Computes the data size of a type, including potentially unused memory from a sparse type.
Implemented in PDI::Array_datatype, PDI::Pointer_datatype, PDI::Record_datatype, PDI::Scalar_datatype, and PDI::Tuple_datatype.
| 
 | pure virtual | 
Returns the required alignment for a type.
Implemented in PDI::Array_datatype, PDI::Pointer_datatype, PDI::Record_datatype, PDI::Scalar_datatype, and PDI::Tuple_datatype.
| 
 | pure virtual | 
Tells if data can be copied as bytes (if type is dense) and doesn't need a destroyer.
Implemented in PDI::Array_datatype, PDI::Pointer_datatype, PDI::Record_datatype, PDI::Scalar_datatype, and PDI::Tuple_datatype.
| 
 | pure virtual | 
Creates a dense deep copy of data.
| [in] | to | the pointer to the allocated memory to fill (dense data) | 
| [in] | from | the pointer to the copied data (size of buffersize) | 
Implemented in PDI::Array_datatype, PDI::Tuple_datatype, PDI::Record_datatype, PDI::Pointer_datatype, and PDI::Scalar_datatype.
| 
 | pure virtual | 
Creates a sparse deep copy of dense data.
| [in] | to | the pointer to the allocated memory to fill (size of buffersize) | 
| [in] | from | the pointer to the copied data (dense data) | 
Implemented in PDI::Array_datatype, PDI::Tuple_datatype, PDI::Record_datatype, PDI::Pointer_datatype, and PDI::Scalar_datatype.
| 
 | virtual | 
Access the type of the element at the provided index.
| index | the index where to look | 
Reimplemented in PDI::Array_datatype, PDI::Pointer_datatype, and PDI::Tuple_datatype.
| 
 | virtual | 
Access the type and value of the element at the provided index.
| index | the index where to look | 
| data | the address of the element to index | 
Reimplemented in PDI::Array_datatype, PDI::Pointer_datatype, and PDI::Tuple_datatype.
| 
 | virtual | 
Access the type of the elements slice between the provided indices.
| start_index | the index where to start | 
| end_index | the index where to end | 
Reimplemented in PDI::Array_datatype, PDI::Pointer_datatype, and PDI::Tuple_datatype.
| 
 | virtual | 
Access the type and value of the elements slice between the provided indices.
| start_index | the index where to start | 
| end_index | the index where to end | 
| data | the address of the element to slice | 
Reimplemented in PDI::Array_datatype, PDI::Pointer_datatype, and PDI::Tuple_datatype.
| 
 | virtual | 
Access the type of the member with the provided name.
| name | the name of the member to access | 
Reimplemented in PDI::Pointer_datatype, and PDI::Record_datatype.
| 
 | virtual | 
Access the type and value of the member with the provided name.
| name | the name of the member to access | 
| data | the address of the element whose member to access | 
Reimplemented in PDI::Pointer_datatype, and PDI::Record_datatype.
| 
 | virtual | 
Access the type referenced by this.
Reimplemented in PDI::Pointer_datatype.
| 
 | virtual | 
Access the type and value referenced by this.
| data | the address of the reference | 
Reimplemented in PDI::Pointer_datatype.
| 
 | pure virtual | 
Delete data whose type is described by the Datatype.
This does not deallocate the buffer used to store the data.
| [in] | ptr | to the data to free | 
Implemented in PDI::Array_datatype, PDI::Record_datatype, PDI::Tuple_datatype, PDI::Pointer_datatype, and PDI::Scalar_datatype.
| 
 | pure virtual | 
Returns the datatype yaml representation as a string.
Implemented in PDI::Array_datatype, PDI::Pointer_datatype, PDI::Record_datatype, PDI::Scalar_datatype, and PDI::Tuple_datatype.