/* * Copyright © 2015 Red Hat, Inc * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library. If not, see . * * Authors: * Alexander Larsson */ #include "config.h" #include #include "flatpak-utils.h" #include "flatpak-related-ref.h" #include "flatpak-related-ref-private.h" #include "flatpak-enum-types.h" /** * SECTION:flatpak-related-ref * @Title: FlatpakRelatedRef * @Short_description: Related application reference * * A FlatpakRelatedRef provides information about an ref that is related * to another ref. For instance, the local extension ref of an app. * * Since: 0.6.7 */ typedef struct _FlatpakRelatedRefPrivate FlatpakRelatedRefPrivate; struct _FlatpakRelatedRefPrivate { char **subpaths; gboolean download; gboolean delete; }; G_DEFINE_TYPE_WITH_PRIVATE (FlatpakRelatedRef, flatpak_related_ref, FLATPAK_TYPE_REF) enum { PROP_0, PROP_SUBPATHS, PROP_SHOULD_DOWNLOAD, PROP_SHOULD_DELETE, }; static void flatpak_related_ref_finalize (GObject *object) { FlatpakRelatedRef *self = FLATPAK_RELATED_REF (object); FlatpakRelatedRefPrivate *priv = flatpak_related_ref_get_instance_private (self); g_strfreev (priv->subpaths); G_OBJECT_CLASS (flatpak_related_ref_parent_class)->finalize (object); } static void flatpak_related_ref_set_property (GObject *object, guint prop_id, const GValue *value, GParamSpec *pspec) { FlatpakRelatedRef *self = FLATPAK_RELATED_REF (object); FlatpakRelatedRefPrivate *priv = flatpak_related_ref_get_instance_private (self); switch (prop_id) { case PROP_SHOULD_DOWNLOAD: priv->download = g_value_get_boolean (value); break; case PROP_SHOULD_DELETE: priv->delete = g_value_get_boolean (value); break; case PROP_SUBPATHS: g_clear_pointer (&priv->subpaths, g_strfreev); priv->subpaths = g_strdupv (g_value_get_boxed (value)); break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); break; } } static void flatpak_related_ref_get_property (GObject *object, guint prop_id, GValue *value, GParamSpec *pspec) { FlatpakRelatedRef *self = FLATPAK_RELATED_REF (object); FlatpakRelatedRefPrivate *priv = flatpak_related_ref_get_instance_private (self); switch (prop_id) { case PROP_SHOULD_DOWNLOAD: g_value_set_boolean (value, priv->download); break; case PROP_SHOULD_DELETE: g_value_set_boolean (value, priv->delete); break; case PROP_SUBPATHS: g_value_set_boxed (value, priv->subpaths); break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); break; } } static void flatpak_related_ref_class_init (FlatpakRelatedRefClass *klass) { GObjectClass *object_class = G_OBJECT_CLASS (klass); object_class->get_property = flatpak_related_ref_get_property; object_class->set_property = flatpak_related_ref_set_property; object_class->finalize = flatpak_related_ref_finalize; g_object_class_install_property (object_class, PROP_SHOULD_DOWNLOAD, g_param_spec_boolean ("should-download", "Should download", "Whether to auto-download the ref with the main ref", FALSE, G_PARAM_READWRITE)); g_object_class_install_property (object_class, PROP_SHOULD_DELETE, g_param_spec_boolean ("should-delete", "Should delete", "Whether to auto-delete the ref with the main ref", FALSE, G_PARAM_READWRITE)); g_object_class_install_property (object_class, PROP_SUBPATHS, g_param_spec_boxed ("subpaths", "", "", G_TYPE_STRV, G_PARAM_READWRITE)); } static void flatpak_related_ref_init (FlatpakRelatedRef *self) { } /** * flatpak_related_ref_get_download: * @self: a #FlatpakRelatedRef * * Returns whether to auto-download the ref with the main ref. * * Returns: %TRUE if the ref should be downloaded with the main ref. * * Since: 0.6.7 */ gboolean flatpak_related_ref_should_download (FlatpakRelatedRef *self) { FlatpakRelatedRefPrivate *priv = flatpak_related_ref_get_instance_private (self); return priv->download; } /** * flatpak_related_ref_should_delete: * @self: a #FlatpakRelatedRef * * Returns whether to auto-delete the ref with the main ref. * * Returns: %TRUE if the ref should be deleted with the main ref. * * Since: 0.6.7 */ gboolean flatpak_related_ref_should_delete (FlatpakRelatedRef *self) { FlatpakRelatedRefPrivate *priv = flatpak_related_ref_get_instance_private (self); return priv->delete; } /** * flatpak_related_ref_get_subpaths: * @self: a #FlatpakRelatedRef * * Returns the subpaths that should be installed/updated for the ref. * This returns %NULL if all files should be installed. * * Returns: (transfer none): A strv, or %NULL * * Since: 0.6.7 */ const char * const * flatpak_related_ref_get_subpaths (FlatpakRelatedRef *self) { FlatpakRelatedRefPrivate *priv = flatpak_related_ref_get_instance_private (self); return (const char * const *) priv->subpaths; } FlatpakRelatedRef * flatpak_related_ref_new (const char *full_ref, const char *commit, char **subpaths, gboolean download, gboolean delete) { FlatpakRefKind kind = FLATPAK_REF_KIND_APP; FlatpakRelatedRef *ref; g_auto(GStrv) parts = NULL; parts = g_strsplit (full_ref, "/", -1); if (strcmp (parts[0], "app") != 0) kind = FLATPAK_REF_KIND_RUNTIME; /* Canonicalize the "no subpaths" case */ if (subpaths && *subpaths == NULL) subpaths = NULL; ref = g_object_new (FLATPAK_TYPE_RELATED_REF, "kind", kind, "name", parts[1], "arch", parts[2], "branch", parts[3], "commit", commit, "subpaths", subpaths, "should-download", download, "should-delete", delete, NULL); return ref; }