mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-14 16:26:17 +01:00
Bug 567906 - Put pkg-config dependencies in .gir files
When generating a .gir file, we now first parse all of our .gir includes to pick up their <package> headers. Then, we merge that with the set of --pkg arguments passed to us, run pkg-config to gather the arguments, and finally save the merged pkg-config list to our new .gir file. This is useful for software which needs to map from .gir to pkg-config in a programmatic way.
This commit is contained in:
parent
97a2e7f5fc
commit
0a74fdfec0
34
girparser.c
34
girparser.c
@ -40,28 +40,29 @@ typedef enum
|
|||||||
STATE_END,
|
STATE_END,
|
||||||
STATE_REPOSITORY,
|
STATE_REPOSITORY,
|
||||||
STATE_INCLUDE,
|
STATE_INCLUDE,
|
||||||
STATE_NAMESPACE,
|
STATE_PACKAGE,
|
||||||
STATE_ENUM, /* 5 */
|
STATE_NAMESPACE, /* 5 */
|
||||||
|
STATE_ENUM,
|
||||||
STATE_BITFIELD,
|
STATE_BITFIELD,
|
||||||
STATE_FUNCTION,
|
STATE_FUNCTION,
|
||||||
STATE_FUNCTION_RETURN,
|
STATE_FUNCTION_RETURN,
|
||||||
STATE_FUNCTION_PARAMETERS,
|
STATE_FUNCTION_PARAMETERS, /* 10 */
|
||||||
STATE_FUNCTION_PARAMETER, /* 10 */
|
STATE_FUNCTION_PARAMETER,
|
||||||
STATE_CLASS,
|
STATE_CLASS,
|
||||||
STATE_CLASS_FIELD,
|
STATE_CLASS_FIELD,
|
||||||
STATE_CLASS_PROPERTY,
|
STATE_CLASS_PROPERTY,
|
||||||
STATE_INTERFACE,
|
STATE_INTERFACE, /* 15 */
|
||||||
STATE_INTERFACE_PROPERTY, /* 15 */
|
STATE_INTERFACE_PROPERTY,
|
||||||
STATE_INTERFACE_FIELD,
|
STATE_INTERFACE_FIELD,
|
||||||
STATE_IMPLEMENTS,
|
STATE_IMPLEMENTS,
|
||||||
STATE_PREREQUISITE,
|
STATE_PREREQUISITE,
|
||||||
STATE_BOXED,
|
STATE_BOXED, /* 20 */
|
||||||
STATE_BOXED_FIELD, /* 20 */
|
STATE_BOXED_FIELD,
|
||||||
STATE_STRUCT,
|
STATE_STRUCT,
|
||||||
STATE_STRUCT_FIELD,
|
STATE_STRUCT_FIELD,
|
||||||
STATE_ERRORDOMAIN,
|
STATE_ERRORDOMAIN,
|
||||||
STATE_UNION,
|
STATE_UNION, /* 25 */
|
||||||
STATE_UNION_FIELD, /* 25 */
|
STATE_UNION_FIELD,
|
||||||
STATE_NAMESPACE_CONSTANT,
|
STATE_NAMESPACE_CONSTANT,
|
||||||
STATE_CLASS_CONSTANT,
|
STATE_CLASS_CONSTANT,
|
||||||
STATE_INTERFACE_CONSTANT,
|
STATE_INTERFACE_CONSTANT,
|
||||||
@ -2584,6 +2585,12 @@ start_element_handler (GMarkupParseContext *context,
|
|||||||
}
|
}
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
else if (strcmp (element_name, "package") == 0 &&
|
||||||
|
ctx->state == STATE_REPOSITORY)
|
||||||
|
{
|
||||||
|
state_switch (ctx, STATE_PACKAGE);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'r':
|
case 'r':
|
||||||
@ -2774,6 +2781,13 @@ end_element_handler (GMarkupParseContext *context,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case STATE_PACKAGE:
|
||||||
|
if (require_end_element (context, ctx, "package", element_name, error))
|
||||||
|
{
|
||||||
|
state_switch (ctx, STATE_REPOSITORY);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case STATE_NAMESPACE:
|
case STATE_NAMESPACE:
|
||||||
if (require_end_element (context, ctx, "namespace", element_name, error))
|
if (require_end_element (context, ctx, "namespace", element_name, error))
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user