+static gboolean module_load(GTypeModule *m)
+{
+ UPkgModule *mod = UPKG_MODULE(m);
+ int (*init_func)(GTypeModule *);
+
+ mod->dl = lt_dlopenext(G_TYPE_MODULE(m)->name);
+ if (!mod->dl) {
+ dl_print_errors(G_TYPE_MODULE(m)->name);
+ return FALSE;
+ }
+
+ init_func = lt_dlsym(mod->dl, "init");
+ if (!init_func || init_func(m) != 0) {
+ dl_print_errors(__func__);
+ lt_dlclose(mod->dl);
+ return FALSE;
+ }
+
+ return TRUE;
+}
+
+static void module_unload(GTypeModule *m)
+{
+ UPkgModule *mod = UPKG_MODULE(m);
+
+ if (lt_dlclose(mod->dl) != 0) {
+ dl_print_errors(__func__);
+ }
+}
+
+static void upkg_module_init(UPkgModule *mod)
+{
+}
+
+static void upkg_module_class_init(UPkgModuleClass *class)
+{
+ GTypeModuleClass *modclass = G_TYPE_MODULE_CLASS(class);
+
+ modclass->load = module_load;
+ modclass->unload = module_unload;
+}
+
+static UPkgModule *uobject_module_new(const char *name)
+{
+ char *name2;
+
+ if (!name) {
+ return NULL;
+ }
+
+ name2 = malloc(strlen(name)+1);
+ if (!name2) {
+ return NULL;
+ }
+
+ UPkgModule *mod = g_object_new(UPKG_MODULE_TYPE, NULL);
+ if (!mod) {
+ free(name2);
+ return NULL;
+ }
+
+ G_TYPE_MODULE(mod)->name = str_cpy_lower(name2, name);
+ return mod;
+}
+
+static int modcmp(const void *a, const void *b, void *_data)
+{
+ const GTypeModule *ma = a;
+ const GTypeModule *mb = b;
+
+ return strcmp(ma->name, mb->name);
+}
+
+int uobject_module_init(void)