diff options
author | Alexander Larsson <alexl@redhat.com> | 2016-05-13 14:17:46 +0200 |
---|---|---|
committer | Alexander Larsson <alexl@redhat.com> | 2016-05-13 14:17:46 +0200 |
commit | 2875cdead5e52279536a72fdbf898eeb2be2c4db (patch) | |
tree | b83f522dffe3034bd31c898c0d569eff609f94fb /app | |
parent | 753cdc97fd31affabb117375fa22bd7929215e8c (diff) | |
download | xdg-app-2875cdead5e52279536a72fdbf898eeb2be2c4db.tar.gz |
remote-delete: Move to FlatpakDir and add checks for installed refs
You can't remove a remote unless you --force or there are no installs
from it.
Diffstat (limited to 'app')
-rw-r--r-- | app/flatpak-builtins-delete-remote.c | 24 |
1 files changed, 9 insertions, 15 deletions
diff --git a/app/flatpak-builtins-delete-remote.c b/app/flatpak-builtins-delete-remote.c index 48330cd..53ab9b9 100644 --- a/app/flatpak-builtins-delete-remote.c +++ b/app/flatpak-builtins-delete-remote.c @@ -30,6 +30,14 @@ #include "flatpak-builtins.h" +static gboolean opt_force; + +static GOptionEntry modify_options[] = { + { "force", 0, 0, G_OPTION_ARG_NONE, &opt_force, "Remove remote even if in use", }, + { NULL } +}; + + gboolean flatpak_builtin_delete_remote (int argc, char **argv, GCancellable *cancellable, GError **error) { @@ -47,23 +55,9 @@ flatpak_builtin_delete_remote (int argc, char **argv, GCancellable *cancellable, remote_name = argv[1]; - if (!flatpak_dir_remove_all_refs (dir, remote_name, - cancellable, error)) - return FALSE; - - if (!flatpak_dir_remove_appstream (dir, remote_name, - cancellable, error)) - return FALSE; - - if (!ostree_repo_remote_change (flatpak_dir_get_repo (dir), NULL, - OSTREE_REPO_REMOTE_CHANGE_DELETE, - remote_name, NULL, - NULL, + if (!flatpak_dir_remove_remote (dir, opt_force, remote_name, cancellable, error)) return FALSE; - if (!flatpak_dir_mark_changed (dir, error)) - return FALSE; - return TRUE; } |