]> git.draconx.ca Git - upkg.git/blobdiff - src/upkg.c
upkg: Print out object file offsets at high verbosity levels.
[upkg.git] / src / upkg.c
index 0e5a84e6dfe907d9ead33f2920b714129d0aa585..7448aba63baf3878b7d48f19da645245e9cfa619 100644 (file)
@@ -262,6 +262,8 @@ static int package_list(GTypeModule *pkg, long parent)
 
                putchar('\n');
        }
+
+       return 0;
 }
 
 static int object_info(GTypeModule *pkg, unsigned long idx)
@@ -276,6 +278,7 @@ static int object_info(GTypeModule *pkg, unsigned long idx)
        class = upkg_export_class(upkg, idx, &package);
        printf(" (%s.%s)\n", package, class);
 
+       /* Print out object properties. */
        if (verbose >= 1) {
                GParamSpec **props;
                GObject *obj;
@@ -293,7 +296,7 @@ static int object_info(GTypeModule *pkg, unsigned long idx)
                        GValue val = {0};
                        char *valstr;
 
-                       printf("  %s: ", props[i]->name);
+                       printf("  property %s: ", props[i]->name);
                        fflush(stdout);
 
                        g_value_init(&val, props[i]->value_type);
@@ -306,6 +309,22 @@ static int object_info(GTypeModule *pkg, unsigned long idx)
                g_object_unref(obj);
        }
 
+       /* Print raw file info. */
+       if (verbose >= 3) {
+               struct upkg_file *f = upkg_export_open(upkg, idx);
+               if (!f) {
+                       fprintf(stderr, "%s: failed to open export.\n",
+                                       progname);
+                       return -1;
+               }
+
+               printf("  file size: %lu\n", f->len);
+               printf("  file start: %#lx\n", f->base);
+               printf("  file end: %#lx\n", f->base + f->len);
+
+               upkg_export_close(f);
+       }
+
        return 0;
 }
 
@@ -314,17 +333,20 @@ static int export(GTypeModule *pkg, GObject *obj, unsigned idx)
        struct upkg *upkg = U_PKG(pkg)->pkg;
        char name[256];
        FILE *of;
+       int rc;
 
-       if (u_object_deserialize(obj, upkg, idx) != 0) {
+       if (U_OBJECT_IS_LOADABLE(obj) && u_object_load(obj) != 0) {
                return -1;
        }
 
-       if (U_OBJECT_IS_LOADABLE(obj) && u_object_load(obj) != 0) {
+       rc = u_object_export_name(obj, name, sizeof name);
+       if (rc <= 0) {
+               /* XXX: We could use a default name here. */
+               fprintf(stderr, "%s: failed to determine export filename.\n",
+                               progname);
                return -1;
        }
 
-       u_object_export_name(obj, name, sizeof name);
-
        printf("exporting ");
        export_print_fullname(pkg, upkg_get_export(upkg, idx));
        printf(" to %s\n", name);
@@ -349,6 +371,29 @@ static int export(GTypeModule *pkg, GObject *obj, unsigned idx)
        return 0;
 }
 
+static int object_export(GTypeModule *pkg, unsigned long idx)
+{
+       struct upkg *upkg = U_PKG(pkg)->pkg;
+       GObject *obj;
+       int ret = -1;
+
+       obj = u_object_new_from_package(upkg, idx);
+       if (!obj) {
+               fprintf(stderr, "%s: failed to load object.\n", progname);
+               return -1;
+       }
+
+       if (!U_OBJECT_IS_EXPORTABLE(obj)) {
+               fprintf(stderr, "%s: object is not exportable.\n", progname);
+               goto out;
+       }
+
+       ret = export(pkg, obj, idx);
+out:
+       g_object_unref(obj);
+       return ret;
+}
+
 int package_export(GTypeModule *pkg)
 {
        struct upkg *upkg = U_PKG(pkg)->pkg;
@@ -365,11 +410,13 @@ int package_export(GTypeModule *pkg)
                }
 
                type = u_object_module_get_class(package, class);
-               if (!type) continue;
+               if (!type)
+                       continue;
 
                obj = g_object_new(type, NULL);
                if (U_OBJECT_IS_EXPORTABLE(obj)) {
-                       if (export(pkg, obj, i) != 0) {
+                       if (u_object_deserialize(obj, upkg, i) != 0
+                           || export(pkg, obj, i) != 0) {
                                ret = -1;
                        }
                }
@@ -440,7 +487,10 @@ static int process_object(int mode, const char *objname)
                ret = package_list(pkg, current+1);
                break;
        case MODE_EXPORT:
-               ret = package_export(pkg);
+               if (current < 0)
+                       ret = package_export(pkg);
+               else
+                       ret = object_export(pkg, current);
                break;
        default:
                abort();