--- /dev/null
+/*
+ Copyright (C) 2012 Modelon AB
+
+ This program is free software: you can redistribute it and/or modify
+ it under the terms of the BSD style license.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ FMILIB_License.txt file for more details.
+
+ You should have received a copy of the FMILIB_License.txt file
+ along with this program. If not, contact Modelon AB <http://www.modelon.com>.
+*/
+
+
+
+/** \file fmi2_import_type.h
+* \brief Public interface to the FMI XML C-library: variable types handling.
+*/
+
+#ifndef FMI2_IMPORT_TYPE_H_
+#define FMI2_IMPORT_TYPE_H_
+
+#include "fmi2_import_unit.h"
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/**
+ \addtogroup fmi2_import
+ @{
+ \addtogroup fmi2_import_typedef Support for processing variable types
+ @}
+ \addtogroup fmi2_import_typedef Support for processing variable types
+ @{
+*/
+/**@name Type definitions supporting structures*/\r
+/**@{ */\r
+/** \brief Opaque type definition object. */\r
+typedef struct fmi2_xml_real_typedef_t fmi2_import_real_typedef_t;\r
+/** \brief Opaque integer type definition object. */\r
+typedef struct fmi2_xml_integer_typedef_t fmi2_import_integer_typedef_t;\r
+/** \brief Opaque enumeration type definition object. */\r
+typedef struct fmi2_xml_enumeration_typedef_t fmi2_import_enumeration_typedef_t;\r
+/** \brief Opaque general variable type definition object. */\r
+typedef struct fmi2_xml_variable_typedef_t fmi2_import_variable_typedef_t;\r
+/** \brief Opaque list of the type definitions in the model */\r
+typedef struct fmi2_xml_type_definitions_t fmi2_import_type_definitions_t;\r
+/**@} */\r
+
+/** \brief Get the number of available type definitions */
+FMILIB_EXPORT unsigned int fmi2_import_get_type_definition_number(fmi2_import_type_definitions_t* td);
+
+/** \brief Get a type definition specified by the index
+ @param td the type definition list object
+ @param index the index of type definition. Must be less than the numbere returned by fmi2_import_get_type_definition_number()
+ @return A type definition object or NULL if index is out of range.
+*/
+FMILIB_EXPORT fmi2_import_variable_typedef_t* fmi2_import_get_typedef(fmi2_import_type_definitions_t* td, unsigned int index);
+
+/** \brief Get associated display unit for a type defition if any. */
+FMILIB_EXPORT fmi2_import_display_unit_t* fmi2_import_get_type_display_unit(fmi2_import_real_typedef_t*);
+
+/** \brief Get the type name*/
+FMILIB_EXPORT const char* fmi2_import_get_type_name(fmi2_import_variable_typedef_t*);
+
+/**\brief Get type description.
+
+ Note that an empty string is returned if the attribute is not present in the XML.*/
+FMILIB_EXPORT const char* fmi2_import_get_type_description(fmi2_import_variable_typedef_t*);
+
+/** \brief Get base type used for the type definition */
+FMILIB_EXPORT fmi2_base_type_enu_t fmi2_import_get_base_type(fmi2_import_variable_typedef_t*);
+
+/* Boolean and String has no extra attributes -> not needed*/
+
+/** \brief Cast the general type definition object to an object with a specific base type
+ @return Pointer to the specific type object or NULL if base type does not match.
+*/
+FMILIB_EXPORT fmi2_import_real_typedef_t* fmi2_import_get_type_as_real(fmi2_import_variable_typedef_t*);
+/** \brief Cast the general type definition object to an object with a specific base type
+ @return Pointer to the specific type object or NULL if base type does not match.
+*/
+FMILIB_EXPORT fmi2_import_integer_typedef_t* fmi2_import_get_type_as_int(fmi2_import_variable_typedef_t*);
+/** \brief Cast the general type definition object to an object with a specific base type
+ @return Pointer to the specific type object or NULL if base type does not match.
+*/
+FMILIB_EXPORT fmi2_import_enumeration_typedef_t* fmi2_import_get_type_as_enum(fmi2_import_variable_typedef_t*);
+
+/** \brief Get the quantity associated with the type definition.
+
+ @return NULL-pointer is always returned for strings and booleans.
+ Empty string is returned if attribute is not present for other types.
+*/
+FMILIB_EXPORT const char* fmi2_import_get_type_quantity(fmi2_import_variable_typedef_t*);
+
+/** \brief Get minimal value for the type.
+
+ @return Either the value specified in the XML file or negated DBL_MAX as defined in <float.h>
+*/
+FMILIB_EXPORT double fmi2_import_get_real_type_min(fmi2_import_real_typedef_t*);
+/** \brief Get maximum value for the type
+
+ @return Either the value specified in the XML file or DBL_MAX as defined in <float.h>
+*/
+FMILIB_EXPORT double fmi2_import_get_real_type_max(fmi2_import_real_typedef_t*);
+
+/** \brief Get the nominal value associated with the type definition */
+FMILIB_EXPORT double fmi2_import_get_real_type_nominal(fmi2_import_real_typedef_t*);
+
+/** \brief Get the unit object associated with the type definition if any*/
+FMILIB_EXPORT fmi2_import_unit_t* fmi2_import_get_real_type_unit(fmi2_import_real_typedef_t*);
+
+/** \brief Get the 'relativeQuantity' flag */
+FMILIB_EXPORT int fmi2_import_get_real_type_is_relative_quantity(fmi2_import_real_typedef_t*);
+
+/** \brief Get the 'unbounded' flag */
+FMILIB_EXPORT int fmi2_import_get_real_type_is_unbounded(fmi2_import_real_typedef_t*);
+
+/** \brief Get minimal value for the type.
+
+ @return Either the value specified in the XML file or INT_MIN as defined in <limits.h>
+*/
+FMILIB_EXPORT int fmi2_import_get_integer_type_min(fmi2_import_integer_typedef_t*);
+/** \brief Get maximum value for the type
+
+ @return Either the value specified in the XML file or INT_MAX as defined in <limits.h>
+*/
+FMILIB_EXPORT int fmi2_import_get_integer_type_max(fmi2_import_integer_typedef_t*);
+
+/** \brief Get minimal value for the type.
+
+ @return Either the value specified in the XML file or 0
+*/
+FMILIB_EXPORT unsigned int fmi2_import_get_enum_type_min(fmi2_import_enumeration_typedef_t*);
+
+/** \brief Get maximum value for the type.
+
+ @return Either the value specified in the XML file or INT_MAX as defined in <limits.h>
+*/
+FMILIB_EXPORT unsigned int fmi2_import_get_enum_type_max(fmi2_import_enumeration_typedef_t*);
+
+/** \brief Get the number of elements in the enum */
+FMILIB_EXPORT unsigned int fmi2_import_get_enum_type_size(fmi2_import_enumeration_typedef_t*);
+
+/** \brief Get an enumeration item name by index */
+FMILIB_EXPORT const char* fmi2_import_get_enum_type_item_name(fmi2_import_enumeration_typedef_t*, unsigned int item);
+
+/** \brief Get an enumeration item value by index */
+FMILIB_EXPORT int fmi2_import_get_enum_type_item_value(fmi2_import_enumeration_typedef_t*, unsigned int item);
+
+/** \brief Get an enumeration item description by index */
+FMILIB_EXPORT const char* fmi2_import_get_enum_type_item_description(fmi2_import_enumeration_typedef_t*, unsigned int item);
+
+/** \brief Get an enumeration item name for the given value */
+FMILIB_EXPORT const char* fmi2_import_get_enum_type_value_name(fmi2_import_enumeration_typedef_t* t, int value);
+
+/**
+ \brief Get display unit associated with a real type definition.
+ @return Display unit object of NULL if none was given.
+*/
+FMILIB_EXPORT fmi2_import_display_unit_t* fmi2_import_get_type_display_unit(fmi2_import_real_typedef_t*);
+
+/**
+* @}
+*/
+#ifdef __cplusplus
+}
+#endif
+#endif
+