From: Nick Bowler Date: Sun, 13 Mar 2011 16:43:29 +0000 (-0400) Subject: upkg: Add support for querying specific objects. X-Git-Url: https://git.draconx.ca/gitweb/upkg.git/commitdiff_plain/d3bcc750280bfce9a7f6e7ccf159400db9ad9659 upkg: Add support for querying specific objects. --- diff --git a/src/libupkg.c b/src/libupkg.c index 680faac..94f0d12 100644 --- a/src/libupkg.c +++ b/src/libupkg.c @@ -46,7 +46,7 @@ struct upkg_name { struct upkg_export_priv { struct upkg_export pub; - long package, class, super; + long class, super; unsigned long size, offset; }; @@ -301,7 +301,7 @@ static int pkg_init_exports(struct upkg_priv *pkg) len += rc; if (nbuf-len < 4) goto err; - export->package = unpack_s32_le(buf+len); + export->pub.package = unpack_s32_le(buf+len); len += 4; rc = upkg_decode_index(&tmp, buf+len, nbuf-len); @@ -504,8 +504,9 @@ long upkg_export_find(struct upkg *pub, long parent, const char *name) struct upkg_export_priv *e = &pkg->exports[i]; /* Assertion: an object's package is an export. */ - format_assert(e->package >= 0, continue); - if (e->package == package && strcmp(e->pub.name, name) == 0) { + format_assert(e->pub.package >= 0, continue); + if (e->pub.package == package + && strcmp(e->pub.name, name) == 0) { return i; } } diff --git a/src/upkg.c b/src/upkg.c index 989bf79..93b3c64 100644 --- a/src/upkg.c +++ b/src/upkg.c @@ -223,6 +223,28 @@ int package_info(struct upkg *pkg) return 0; } +static void export_print_name(struct upkg *upkg, const struct upkg_export *e) +{ + if (e) { + export_print_name(upkg, upkg_get_export(upkg, e->package-1)); + printf(".%s", e->name); + } +} + +static int export_info(GTypeModule *pkg, unsigned long idx) +{ + struct upkg *upkg = U_PKG(pkg)->pkg; + const struct upkg_export *export; + + export = upkg_get_export(upkg, idx); + + printf("%s", pkg->name); + export_print_name(upkg, export); + putchar('\n'); + + return 0; +} + static int export(struct upkg *pkg, GObject *obj, unsigned idx) { const struct upkg_export *export = upkg_get_export(pkg, idx); @@ -341,7 +363,10 @@ static int process_object(int mode, const char *objname) switch (mode) { case MODE_INFO: - ret = package_info(U_PKG(pkg)->pkg); + if (current < 0) + ret = package_info(U_PKG(pkg)->pkg); + else + ret = export_info(pkg, current); break; case MODE_EXPORT: ret = package_export(U_PKG(pkg)->pkg); diff --git a/src/upkg.h b/src/upkg.h index 044b107..4f93f9c 100644 --- a/src/upkg.h +++ b/src/upkg.h @@ -79,7 +79,9 @@ struct upkg { struct upkg_export { const char *name; + unsigned long flags; + long package; }; struct upkg_file {