/* * libosinfo: a list of pre-installed images * * Copyright (C) 2018-2020 Red Hat, Inc. * * This library 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 * . */ #include #include /** * SECTION:osinfo_imagelist * @short_description: A list of pre-installated images * @see_also: #OsinfoList, #OsinfoImage * * #OsinfoImageList is a list specialization that stores * only #OsinfoImage objects. */ struct _OsinfoImageListPrivate { gboolean unused; }; G_DEFINE_TYPE_WITH_PRIVATE(OsinfoImageList, osinfo_imagelist, OSINFO_TYPE_LIST); static void osinfo_imagelist_finalize(GObject *object) { /* Chain up to the parent class */ G_OBJECT_CLASS(osinfo_imagelist_parent_class)->finalize(object); } /* Init functions */ static void osinfo_imagelist_class_init(OsinfoImageListClass *klass) { GObjectClass *g_klass = G_OBJECT_CLASS(klass); g_klass->finalize = osinfo_imagelist_finalize; } static void osinfo_imagelist_init(OsinfoImageList *list) { list->priv = osinfo_imagelist_get_instance_private(list); } /** * osinfo_imagelist_new: * * Construct a new image list that is initially empty. * * Returns: (transfer full): an empty image list * * Since: 1.3.0 */ OsinfoImageList *osinfo_imagelist_new(void) { return g_object_new(OSINFO_TYPE_IMAGELIST, "element-type", OSINFO_TYPE_IMAGE, NULL); }