lib: Use the new remote helpers

tingping/wmclass
Alexander Larsson 2015-12-04 10:49:16 +01:00
parent 4cdec26264
commit 2f6fc54897
3 changed files with 36 additions and 51 deletions

View File

@ -251,10 +251,8 @@ xdg_app_installation_list_installed_refs (XdgAppInstallation *self,
return NULL; return NULL;
for (i = 0; raw_refs[i] != NULL; i++) for (i = 0; raw_refs[i] != NULL; i++)
{ g_ptr_array_add (refs,
g_ptr_array_add (refs, get_ref (self, raw_refs[i], cancellable));
get_ref (self, raw_refs[i], cancellable));
}
g_ptr_array_add (refs, NULL); g_ptr_array_add (refs, NULL);
return (XdgAppInstalledRef **)g_ptr_array_free (g_steal_pointer (&refs), FALSE); return (XdgAppInstalledRef **)g_ptr_array_free (g_steal_pointer (&refs), FALSE);
@ -268,24 +266,15 @@ xdg_app_installation_list_remotes (XdgAppInstallation *self,
XdgAppInstallationPrivate *priv = xdg_app_installation_get_instance_private (self); XdgAppInstallationPrivate *priv = xdg_app_installation_get_instance_private (self);
g_auto(GStrv) remote_names = NULL; g_auto(GStrv) remote_names = NULL;
g_autoptr(GPtrArray) remotes = g_ptr_array_new_with_free_func (g_object_unref); g_autoptr(GPtrArray) remotes = g_ptr_array_new_with_free_func (g_object_unref);
guint n_remotes;
OstreeRepo *repo;
int i; int i;
if (!xdg_app_dir_ensure_repo (priv->dir, cancellable, error)) remote_names = xdg_app_dir_list_remotes (priv->dir, cancellable, error);
return FALSE; if (remote_names == NULL)
return NULL;
repo = xdg_app_dir_get_repo (priv->dir); for (i = 0; remote_names[i] != NULL; i++)
remote_names = ostree_repo_remote_list (repo, &n_remotes); g_ptr_array_add (remotes,
xdg_app_remote_new (priv->dir, remote_names[i]));
if (remote_names)
{
for (i = 0; remote_names[i] != NULL; i++)
{
g_ptr_array_add (remotes,
xdg_app_remote_new (repo, remote_names[i]));
}
}
g_ptr_array_add (remotes, NULL); g_ptr_array_add (remotes, NULL);
return (XdgAppRemote **)g_ptr_array_free (g_steal_pointer (&remotes), FALSE); return (XdgAppRemote **)g_ptr_array_free (g_steal_pointer (&remotes), FALSE);

View File

@ -26,8 +26,9 @@
#define __XDG_APP_REMOTE_PRIVATE_H__ #define __XDG_APP_REMOTE_PRIVATE_H__
#include <xdg-app-remote.h> #include <xdg-app-remote.h>
#include <xdg-app-dir.h>
#include <ostree.h> #include <ostree.h>
XdgAppRemote *xdg_app_remote_new (OstreeRepo *repo, const char *name); XdgAppRemote *xdg_app_remote_new (XdgAppDir *dir, const char *name);
#endif /* __XDG_APP_REMOTE_PRIVATE_H__ */ #endif /* __XDG_APP_REMOTE_PRIVATE_H__ */

View File

@ -33,7 +33,7 @@ struct _XdgAppRemotePrivate
char *name; char *name;
char *url; char *url;
char *title; char *title;
OstreeRepo *repo; XdgAppDir *dir;
}; };
G_DEFINE_TYPE_WITH_PRIVATE (XdgAppRemote, xdg_app_remote, G_TYPE_OBJECT) G_DEFINE_TYPE_WITH_PRIVATE (XdgAppRemote, xdg_app_remote, G_TYPE_OBJECT)
@ -53,8 +53,8 @@ xdg_app_remote_finalize (GObject *object)
g_free (priv->name); g_free (priv->name);
g_free (priv->url); g_free (priv->url);
g_free (priv->title); g_free (priv->title);
g_object_unref (priv->repo); g_object_unref (priv->dir);
G_OBJECT_CLASS (xdg_app_remote_parent_class)->finalize (object); G_OBJECT_CLASS (xdg_app_remote_parent_class)->finalize (object);
} }
@ -136,9 +136,10 @@ const char *
xdg_app_remote_get_url (XdgAppRemote *self) xdg_app_remote_get_url (XdgAppRemote *self)
{ {
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self); XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
OstreeRepo *repo = xdg_app_dir_get_repo (priv->dir);
if (priv->url == NULL) if (priv->url == NULL)
ostree_repo_remote_get_url (priv->repo, priv->name, &priv->url, NULL); ostree_repo_remote_get_url (repo, priv->name, &priv->url, NULL);
return priv->url; return priv->url;
} }
@ -147,14 +148,9 @@ const char *
xdg_app_remote_get_title (XdgAppRemote *self) xdg_app_remote_get_title (XdgAppRemote *self)
{ {
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self); XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
GKeyFile *config;
if (priv->title == NULL) if (priv->title == NULL)
{ priv->title = xdg_app_dir_get_remote_title (priv->dir, priv->name);
g_autofree char *group = g_strdup_printf ("remote \"%s\"", priv->name);
config = ostree_repo_get_config (priv->repo);
priv->title = g_key_file_get_string (config, group, "xa.title", NULL);
}
return priv->title ? priv->title : priv->name; return priv->title ? priv->title : priv->name;
} }
@ -163,9 +159,10 @@ gboolean
xdg_app_remote_get_gpg_verify (XdgAppRemote *self) xdg_app_remote_get_gpg_verify (XdgAppRemote *self)
{ {
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self); XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
OstreeRepo *repo = xdg_app_dir_get_repo (priv->dir);
gboolean res; gboolean res;
if (ostree_repo_remote_get_gpg_verify (priv->repo, priv->name, &res, NULL)) if (ostree_repo_remote_get_gpg_verify (repo, priv->name, &res, NULL))
return res; return res;
return FALSE; return FALSE;
@ -198,30 +195,28 @@ xdg_app_remote_list_refs (XdgAppRemote *self,
GCancellable *cancellable, GCancellable *cancellable,
GError **error) GError **error)
{ {
XdgAppRemotePrivate *priv = xdg_app_remote_get_instance_private (self);
g_autoptr(GPtrArray) refs = g_ptr_array_new_with_free_func (g_object_unref); g_autoptr(GPtrArray) refs = g_ptr_array_new_with_free_func (g_object_unref);
g_autoptr(GHashTable) ht = NULL; g_autoptr(GHashTable) ht = NULL;
const char *url;
g_autofree char *title = NULL;
GHashTableIter iter; GHashTableIter iter;
gpointer key; gpointer key;
gpointer value; gpointer value;
url = xdg_app_remote_get_url (self); if (!xdg_app_dir_list_remote_refs (priv->dir,
g_print ("url: %s\n", url); priv->name,
if (url) &ht,
cancellable,
error))
return NULL;
g_hash_table_iter_init (&iter, ht);
while (g_hash_table_iter_next (&iter, &key, &value))
{ {
if (!ostree_repo_load_summary (url, &ht, &title, cancellable, error)) const char *refspec = key;
return FALSE; const char *checksum = value;
g_hash_table_iter_init (&iter, ht); g_ptr_array_add (refs,
while (g_hash_table_iter_next (&iter, &key, &value)) get_ref (self, refspec, checksum));
{
const char *refspec = key;
const char *checksum = value;
g_ptr_array_add (refs,
get_ref (self, refspec, checksum));
}
} }
g_ptr_array_add (refs, NULL); g_ptr_array_add (refs, NULL);
@ -230,16 +225,16 @@ xdg_app_remote_list_refs (XdgAppRemote *self,
XdgAppRemote * XdgAppRemote *
xdg_app_remote_new (OstreeRepo *repo, xdg_app_remote_new (XdgAppDir *dir,
const char *name) const char *name)
{ {
XdgAppRemotePrivate *priv; XdgAppRemotePrivate *priv;
XdgAppRemote *self = g_object_new (XDG_APP_TYPE_REMOTE, XdgAppRemote *self = g_object_new (XDG_APP_TYPE_REMOTE,
"name", name, "name", name,
NULL); NULL);
priv = xdg_app_remote_get_instance_private (self); priv = xdg_app_remote_get_instance_private (self);
priv->repo = g_object_ref (repo); priv->dir = g_object_ref (dir);
return self; return self;
} }