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:
Colin Walters 2009-02-05 17:36:35 -05:00
parent 97a2e7f5fc
commit 0a74fdfec0

View File

@ -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))
{ {