summaryrefslogtreecommitdiff
path: root/src/lib/eolian
diff options
context:
space:
mode:
authorDaniel Kolesa <d.kolesa@osg.samsung.com>2016-01-26 15:28:41 +0000
committerDaniel Kolesa <d.kolesa@osg.samsung.com>2016-03-03 18:58:11 +0000
commit6e2497bc014397c4ec9fe78cf06b1f9412cabb68 (patch)
tree932cf3177021100c60cf82e75aba0ac0a0dcb40d /src/lib/eolian
parent2be79061fd106348722beca41e2921ec1b14a26d (diff)
downloadefl-6e2497bc014397c4ec9fe78cf06b1f9412cabb68.tar.gz
eolian: add wrappers for most of typedecl APIs
Diffstat (limited to 'src/lib/eolian')
-rw-r--r--src/lib/eolian/Eolian.h21
-rw-r--r--src/lib/eolian/database_type_api.c124
2 files changed, 145 insertions, 0 deletions
diff --git a/src/lib/eolian/Eolian.h b/src/lib/eolian/Eolian.h
index f88dd45582..f91989d0a1 100644
--- a/src/lib/eolian/Eolian.h
+++ b/src/lib/eolian/Eolian.h
@@ -1276,6 +1276,7 @@ EAPI Eina_Stringshare *eolian_class_c_get_function_name_get(const Eolian_Class *
* @ingroup Eolian
*/
EAPI const Eolian_Type *eolian_type_alias_get_by_name(const char *name);
+EAPI const Eolian_Typedecl *eolian_typedecl_alias_get_by_name(const char *name);
/*
* @brief Get a struct by name. Supports namespaces.
@@ -1286,6 +1287,7 @@ EAPI const Eolian_Type *eolian_type_alias_get_by_name(const char *name);
* @ingroup Eolian
*/
EAPI const Eolian_Type *eolian_type_struct_get_by_name(const char *name);
+EAPI const Eolian_Typedecl *eolian_typedecl_struct_get_by_name(const char *name);
/*
* @brief Get an enum by name. Supports namespaces.
@@ -1296,6 +1298,7 @@ EAPI const Eolian_Type *eolian_type_struct_get_by_name(const char *name);
* @ingroup Eolian
*/
EAPI const Eolian_Type *eolian_type_enum_get_by_name(const char *name);
+EAPI const Eolian_Typedecl *eolian_typedecl_enum_get_by_name(const char *name);
/*
* @brief Get an iterator to all aliases contained in a file.
@@ -1342,6 +1345,7 @@ EAPI Eina_Iterator *eolian_type_enums_get_by_file(const char *fname);
* @ingroup Eolian
*/
EAPI Eolian_Type_Type eolian_type_type_get(const Eolian_Type *tp);
+EAPI Eolian_Typedecl_Type eolian_typedecl_type_get(const Eolian_Typedecl *tp);
/*
* @brief Get an iterator to all subtypes of a type.
@@ -1362,6 +1366,7 @@ EAPI Eina_Iterator *eolian_type_subtypes_get(const Eolian_Type *tp);
* @ingroup Eolian
*/
EAPI Eina_Iterator *eolian_type_struct_fields_get(const Eolian_Type *tp);
+EAPI Eina_Iterator *eolian_typedecl_struct_fields_get(const Eolian_Typedecl *tp);
/*
* @brief Get a field of a struct type.
@@ -1374,6 +1379,7 @@ EAPI Eina_Iterator *eolian_type_struct_fields_get(const Eolian_Type *tp);
* @ingroup Eolian
*/
EAPI const Eolian_Struct_Type_Field *eolian_type_struct_field_get(const Eolian_Type *tp, const char *field);
+EAPI const Eolian_Struct_Type_Field *eolian_typedecl_struct_field_get(const Eolian_Typedecl *tp, const char *field);
/*
* @brief Get the name of a field of a struct type.
@@ -1384,6 +1390,7 @@ EAPI const Eolian_Struct_Type_Field *eolian_type_struct_field_get(const Eolian_T
* @ingroup Eolian
*/
EAPI Eina_Stringshare *eolian_type_struct_field_name_get(const Eolian_Struct_Type_Field *fl);
+#define eolian_typedecl_struct_field_name_get eolian_type_struct_field_name_get
/*
* @brief Get the documentation of a field of a struct type.
@@ -1394,6 +1401,7 @@ EAPI Eina_Stringshare *eolian_type_struct_field_name_get(const Eolian_Struct_Typ
* @ingroup Eolian
*/
EAPI const Eolian_Documentation *eolian_type_struct_field_documentation_get(const Eolian_Struct_Type_Field *fl);
+#define eolian_typedecl_struct_field_documentation_get eolian_type_struct_field_documentation_get
/*
* @brief Get the type of a field of a struct type.
@@ -1404,6 +1412,7 @@ EAPI const Eolian_Documentation *eolian_type_struct_field_documentation_get(cons
* @ingroup Eolian
*/
EAPI const Eolian_Type *eolian_type_struct_field_type_get(const Eolian_Struct_Type_Field *fl);
+#define eolian_typedecl_struct_field_type_get eolian_type_struct_field_type_get
/*
* @brief Get an iterator to all fields of an enum type.
@@ -1414,6 +1423,7 @@ EAPI const Eolian_Type *eolian_type_struct_field_type_get(const Eolian_Struct_Ty
* @ingroup Eolian
*/
EAPI Eina_Iterator *eolian_type_enum_fields_get(const Eolian_Type *tp);
+EAPI Eina_Iterator *eolian_typedecl_enum_fields_get(const Eolian_Typedecl *tp);
/*
* @brief Get a field of an enum type.
@@ -1429,6 +1439,7 @@ EAPI Eina_Iterator *eolian_type_enum_fields_get(const Eolian_Type *tp);
* @ingroup Eolian
*/
EAPI const Eolian_Enum_Type_Field *eolian_type_enum_field_get(const Eolian_Type *tp, const char *field);
+EAPI const Eolian_Enum_Type_Field *eolian_typedecl_enum_field_get(const Eolian_Typedecl *tp, const char *field);
/*
* @brief Get the name of a field of an enum type.
@@ -1439,6 +1450,7 @@ EAPI const Eolian_Enum_Type_Field *eolian_type_enum_field_get(const Eolian_Type
* @ingroup Eolian
*/
EAPI Eina_Stringshare *eolian_type_enum_field_name_get(const Eolian_Enum_Type_Field *fl);
+#define eolian_typedecl_enum_field_name_get eolian_type_enum_field_name_get
/*
* @brief Get the C name of a field of an enum type.
@@ -1451,6 +1463,7 @@ EAPI Eina_Stringshare *eolian_type_enum_field_name_get(const Eolian_Enum_Type_Fi
* @ingroup Eolian
*/
EAPI Eina_Stringshare *eolian_type_enum_field_c_name_get(const Eolian_Enum_Type_Field *fl);
+#define eolian_typedecl_enum_field_c_name_get eolian_type_enum_field_c_name_get
/*
* @brief Get the documentation of a field of an enum type.
@@ -1461,6 +1474,7 @@ EAPI Eina_Stringshare *eolian_type_enum_field_c_name_get(const Eolian_Enum_Type_
* @ingroup Eolian
*/
EAPI const Eolian_Documentation *eolian_type_enum_field_documentation_get(const Eolian_Enum_Type_Field *fl);
+#define eolian_typedecl_enum_field_documentation_get eolian_type_enum_field_documentation_get
/*
* @brief Get the value of a field of an enum type.
@@ -1476,6 +1490,7 @@ EAPI const Eolian_Documentation *eolian_type_enum_field_documentation_get(const
* @ingroup Eolian
*/
EAPI const Eolian_Expression *eolian_type_enum_field_value_get(const Eolian_Enum_Type_Field *fl, Eina_Bool force);
+#define eolian_typedecl_enum_field_value_get eolian_type_enum_field_value_get
/*
* @brief Get the legacy prefix of enum field names. When not specified,
@@ -1487,6 +1502,7 @@ EAPI const Eolian_Expression *eolian_type_enum_field_value_get(const Eolian_Enum
* @ingroup Eolian
*/
EAPI Eina_Stringshare *eolian_type_enum_legacy_prefix_get(const Eolian_Type *tp);
+EAPI Eina_Stringshare *eolian_typedecl_enum_legacy_prefix_get(const Eolian_Typedecl *tp);
/*
* @brief Get the documentation of a struct/alias type.
@@ -1498,6 +1514,7 @@ EAPI Eina_Stringshare *eolian_type_enum_legacy_prefix_get(const Eolian_Type *tp)
* @ingroup Eolian
*/
EAPI const Eolian_Documentation *eolian_type_documentation_get(const Eolian_Type *tp);
+EAPI const Eolian_Documentation *eolian_typedecl_documentation_get(const Eolian_Typedecl *tp);
/*
* @brief Get the filename of a struct/alias type.
@@ -1508,6 +1525,7 @@ EAPI const Eolian_Documentation *eolian_type_documentation_get(const Eolian_Type
* @ingroup Eolian
*/
EAPI Eina_Stringshare *eolian_type_file_get(const Eolian_Type *tp);
+EAPI Eina_Stringshare *eolian_typedecl_file_get(const Eolian_Typedecl *tp);
/*
* @brief Get the base type of a pointer, alias or regular type.
@@ -1521,6 +1539,7 @@ EAPI Eina_Stringshare *eolian_type_file_get(const Eolian_Type *tp);
* @ingroup Eolian
*/
EAPI const Eolian_Type *eolian_type_base_type_get(const Eolian_Type *tp);
+EAPI const Eolian_Type *eolian_typedecl_base_type_get(const Eolian_Typedecl *tp);
/*
* @brief Get the lowest base type of an alias stack.
@@ -1538,6 +1557,7 @@ EAPI const Eolian_Type *eolian_type_base_type_get(const Eolian_Type *tp);
* @ingroup Eolian
*/
EAPI const Eolian_Type *eolian_type_aliased_base_get(const Eolian_Type *tp);
+EAPI const Eolian_Type *eolian_typedecl_aliased_base_get(const Eolian_Typedecl *tp);
/*
* @brief Get the class associated with an EOLIAN_TYPE_CLASS type.
@@ -1580,6 +1600,7 @@ EAPI Eina_Bool eolian_type_is_const(const Eolian_Type *tp);
* @ingroup Eolian
*/
EAPI Eina_Bool eolian_type_is_extern(const Eolian_Type *tp);
+EAPI Eina_Bool eolian_typedecl_is_extern(const Eolian_Typedecl *tp);
/*
* @brief Get the full C type name of the given type with a name.
diff --git a/src/lib/eolian/database_type_api.c b/src/lib/eolian/database_type_api.c
index 392d40a64b..ddfdcb46dd 100644
--- a/src/lib/eolian/database_type_api.c
+++ b/src/lib/eolian/database_type_api.c
@@ -16,6 +16,14 @@ eolian_type_alias_get_by_name(const char *name)
return tp;
}
+EAPI const Eolian_Typedecl *
+eolian_typedecl_alias_get_by_name(const char *name)
+{
+ const Eolian_Type *ret = eolian_type_alias_get_by_name(name);
+ if (!ret) return NULL;
+ return ret->decl;
+}
+
EAPI const Eolian_Type *
eolian_type_struct_get_by_name(const char *name)
{
@@ -26,6 +34,14 @@ eolian_type_struct_get_by_name(const char *name)
return tp;
}
+EAPI const Eolian_Typedecl *
+eolian_typedecl_struct_get_by_name(const char *name)
+{
+ const Eolian_Type *ret = eolian_type_struct_get_by_name(name);
+ if (!ret) return NULL;
+ return ret->decl;
+}
+
EAPI const Eolian_Type *
eolian_type_enum_get_by_name(const char *name)
{
@@ -36,6 +52,14 @@ eolian_type_enum_get_by_name(const char *name)
return tp;
}
+EAPI const Eolian_Typedecl *
+eolian_typedecl_enum_get_by_name(const char *name)
+{
+ const Eolian_Type *ret = eolian_type_enum_get_by_name(name);
+ if (!ret) return NULL;
+ return ret->decl;
+}
+
EAPI Eina_Iterator *
eolian_type_aliases_get_by_file(const char *fname)
{
@@ -76,6 +100,13 @@ eolian_type_type_get(const Eolian_Type *tp)
return tp->type;
}
+EAPI Eolian_Typedecl_Type
+eolian_typedecl_type_get(const Eolian_Typedecl *tp)
+{
+ EINA_SAFETY_ON_NULL_RETURN_VAL(tp, EOLIAN_TYPEDECL_UNKNOWN);
+ return tp->type;
+}
+
EAPI Eina_Iterator *
eolian_type_subtypes_get(const Eolian_Type *tp)
{
@@ -96,6 +127,15 @@ eolian_type_struct_fields_get(const Eolian_Type *tp)
return eina_list_iterator_new(tp->field_list);
}
+EAPI Eina_Iterator *
+eolian_typedecl_struct_fields_get(const Eolian_Typedecl *tp)
+{
+ EINA_SAFETY_ON_NULL_RETURN_VAL(tp, NULL);
+ if (tp->type != EOLIAN_TYPEDECL_STRUCT)
+ return NULL;
+ return eina_list_iterator_new(tp->field_list);
+}
+
EAPI const Eolian_Struct_Type_Field *
eolian_type_struct_field_get(const Eolian_Type *tp, const char *field)
{
@@ -109,6 +149,19 @@ eolian_type_struct_field_get(const Eolian_Type *tp, const char *field)
return sf;
}
+EAPI const Eolian_Struct_Type_Field *
+eolian_typedecl_struct_field_get(const Eolian_Typedecl *tp, const char *field)
+{
+ Eolian_Struct_Type_Field *sf = NULL;
+ EINA_SAFETY_ON_NULL_RETURN_VAL(tp, NULL);
+ EINA_SAFETY_ON_NULL_RETURN_VAL(field, NULL);
+ if (tp->type != EOLIAN_TYPEDECL_STRUCT)
+ return NULL;
+ sf = eina_hash_find(tp->fields, field);
+ if (!sf) return NULL;
+ return sf;
+}
+
EAPI Eina_Stringshare *
eolian_type_struct_field_name_get(const Eolian_Struct_Type_Field *fl)
{
@@ -139,6 +192,15 @@ eolian_type_enum_fields_get(const Eolian_Type *tp)
return eina_list_iterator_new(tp->field_list);
}
+EAPI Eina_Iterator *
+eolian_typedecl_enum_fields_get(const Eolian_Typedecl *tp)
+{
+ EINA_SAFETY_ON_NULL_RETURN_VAL(tp, NULL);
+ if (tp->type != EOLIAN_TYPEDECL_ENUM)
+ return NULL;
+ return eina_list_iterator_new(tp->field_list);
+}
+
EAPI const Eolian_Enum_Type_Field *
eolian_type_enum_field_get(const Eolian_Type *tp, const char *field)
{
@@ -152,6 +214,19 @@ eolian_type_enum_field_get(const Eolian_Type *tp, const char *field)
return ef;
}
+EAPI const Eolian_Enum_Type_Field *
+eolian_typedecl_enum_field_get(const Eolian_Typedecl *tp, const char *field)
+{
+ Eolian_Enum_Type_Field *ef = NULL;
+ EINA_SAFETY_ON_NULL_RETURN_VAL(tp, NULL);
+ EINA_SAFETY_ON_NULL_RETURN_VAL(field, NULL);
+ if (tp->type != EOLIAN_TYPEDECL_ENUM)
+ return NULL;
+ ef = eina_hash_find(tp->fields, field);
+ if (!ef) return NULL;
+ return ef;
+}
+
EAPI Eina_Stringshare *
eolian_type_enum_field_name_get(const Eolian_Enum_Type_Field *fl)
{
@@ -206,6 +281,15 @@ eolian_type_enum_legacy_prefix_get(const Eolian_Type *tp)
return tp->legacy;
}
+EAPI Eina_Stringshare *
+eolian_typedecl_enum_legacy_prefix_get(const Eolian_Typedecl *tp)
+{
+ EINA_SAFETY_ON_NULL_RETURN_VAL(tp, NULL);
+ if (tp->type != EOLIAN_TYPEDECL_ENUM)
+ return NULL;
+ return tp->legacy;
+}
+
EAPI const Eolian_Documentation *
eolian_type_documentation_get(const Eolian_Type *tp)
{
@@ -213,6 +297,13 @@ eolian_type_documentation_get(const Eolian_Type *tp)
return tp->doc;
}
+EAPI const Eolian_Documentation *
+eolian_typedecl_documentation_get(const Eolian_Typedecl *tp)
+{
+ EINA_SAFETY_ON_NULL_RETURN_VAL(tp, NULL);
+ return tp->doc;
+}
+
EAPI Eina_Stringshare *
eolian_type_file_get(const Eolian_Type *tp)
{
@@ -220,6 +311,13 @@ eolian_type_file_get(const Eolian_Type *tp)
return tp->base.file;
}
+EAPI Eina_Stringshare *
+eolian_typedecl_file_get(const Eolian_Typedecl *tp)
+{
+ EINA_SAFETY_ON_NULL_RETURN_VAL(tp, NULL);
+ return tp->base.file;
+}
+
EAPI const Eolian_Type *
eolian_type_base_type_get(const Eolian_Type *tp)
{
@@ -249,6 +347,17 @@ eolian_type_base_type_get(const Eolian_Type *tp)
}
EAPI const Eolian_Type *
+eolian_typedecl_base_type_get(const Eolian_Typedecl *tp)
+{
+ Eolian_Typedecl_Type tpt;
+ EINA_SAFETY_ON_NULL_RETURN_VAL(tp, NULL);
+ tpt = eolian_typedecl_type_get(tp);
+ if (tpt != EOLIAN_TYPEDECL_ALIAS)
+ return NULL;
+ return tp->base_type;
+}
+
+EAPI const Eolian_Type *
eolian_type_aliased_base_get(const Eolian_Type *tp)
{
if (!tp)
@@ -265,6 +374,14 @@ eolian_type_aliased_base_get(const Eolian_Type *tp)
return eolian_type_aliased_base_get(tp->base_type);
}
+EAPI const Eolian_Type *
+eolian_typedecl_aliased_base_get(const Eolian_Typedecl *tp)
+{
+ if (!tp || tp->type != EOLIAN_TYPEDECL_ALIAS)
+ return NULL;
+ return eolian_type_aliased_base_get(tp->base_type);
+}
+
EAPI const Eolian_Class *
eolian_type_class_get(const Eolian_Type *tp)
{
@@ -295,6 +412,13 @@ eolian_type_is_extern(const Eolian_Type *tp)
return tp->is_extern;
}
+EAPI Eina_Bool
+eolian_typedecl_is_extern(const Eolian_Typedecl *tp)
+{
+ EINA_SAFETY_ON_NULL_RETURN_VAL(tp, EINA_FALSE);
+ return tp->is_extern;
+}
+
EAPI Eina_Stringshare *
eolian_type_c_type_named_get(const Eolian_Type *tp, const char *name)
{