]> git.draconx.ca Git - upkg.git/blobdiff - src/upkg.c
uobject: Add a helper function to load objects from packages.
[upkg.git] / src / upkg.c
index 24df29357d4f486871ee549a1914220c4464d0a1..c13a867f7b1dfd8cbdbf21977c537ccc89d8da19 100644 (file)
@@ -35,6 +35,7 @@
 
 enum {
        MODE_INFO,
+       MODE_LIST,
        MODE_EXPORT,
        MODE_MAX
 };
@@ -42,9 +43,10 @@ enum {
 int verbose = 0;
 
 static const char *progname = "upkg";
-static const char *sopts = "ixvf:VH";
+static const char *sopts = "ilxvf:VH";
 static const struct option lopts[] = {
        { "info",     0, NULL, 'i' },
+       { "list",     0, NULL, 'l' },
        { "export",   0, NULL, 'x' },
        { "file",     1, NULL, 'f' },
        { "verbose",  0, NULL, 'v' },
@@ -231,16 +233,78 @@ static void export_print_name(struct upkg *upkg, const struct upkg_export *e)
        }
 }
 
-static int export_info(GTypeModule *pkg, unsigned long idx)
+static void
+export_print_fullname(GTypeModule *pkg, const struct upkg_export *export)
+{
+       printf("%s", pkg->name);
+       export_print_name(U_PKG(pkg)->pkg, export);
+}
+
+static int package_list(GTypeModule *pkg, long parent)
 {
        struct upkg *upkg = U_PKG(pkg)->pkg;
        const struct upkg_export *export;
 
+       for (unsigned i = 0; i < upkg->export_count; i++) {
+               export = upkg_get_export(upkg, i);
+
+               if (export->package != parent)
+                       continue;
+
+               export_print_fullname(pkg, export);
+
+               if (verbose >= 1) {
+                       const char *class, *package;
+
+                       class = upkg_export_class(upkg, i, &package);
+                       printf(" (%s.%s)", package, class);
+               }
+
+               putchar('\n');
+       }
+}
+
+static int object_info(GTypeModule *pkg, unsigned long idx)
+{
+       struct upkg *upkg = U_PKG(pkg)->pkg;
+       const struct upkg_export *export;
+       const char *class, *package;
+
        export = upkg_get_export(upkg, idx);
+       export_print_fullname(pkg, export);
 
-       printf("%s", pkg->name);
-       export_print_name(upkg, export);
-       putchar('\n');
+       class = upkg_export_class(upkg, idx, &package);
+       printf(" (%s.%s)\n", package, class);
+
+       if (verbose >= 1) {
+               GParamSpec **props;
+               GObject *obj;
+               unsigned n;
+
+               obj = u_object_new_from_package(upkg, idx);
+               if (!obj) {
+                       fprintf(stderr, "%s: failed to load object.\n",
+                                       progname);
+                       return -1;
+               }
+
+               props = g_object_class_list_properties(G_OBJECT_GET_CLASS(obj), &n);
+               for (unsigned i = 0; i < n; i++) {
+                       GValue val = {0};
+                       char *valstr;
+
+                       printf("  %s: ", props[i]->name);
+                       fflush(stdout);
+
+                       g_value_init(&val, props[i]->value_type);
+                       g_object_get_property(obj, props[i]->name, &val);
+                       valstr = g_strdup_value_contents(&val);
+                       printf("%s\n", valstr);
+               }
+               free(props);
+
+               g_object_unref(obj);
+       }
 
        return 0;
 }
@@ -366,7 +430,10 @@ static int process_object(int mode, const char *objname)
                if (current < 0)
                        ret = package_info(U_PKG(pkg)->pkg);
                else
-                       ret = export_info(pkg, current);
+                       ret = object_info(pkg, current);
+               break;
+       case MODE_LIST:
+               ret = package_list(pkg, current+1);
                break;
        case MODE_EXPORT:
                ret = package_export(U_PKG(pkg)->pkg);
@@ -406,6 +473,9 @@ int main(int argc, char **argv)
                case 'i':
                        mode = MODE_INFO;
                        break;
+               case 'l':
+                       mode = MODE_LIST;
+                       break;
                case 'x':
                        mode = MODE_EXPORT;
                        break;