/* * This file is part of libmodulemd * Copyright (C) 2017-2018 Stephen Gallagher * * Fedora-License-Identifier: MIT * SPDX-2.0-License-Identifier: MIT * SPDX-3.0-License-Identifier: MIT * * This program is free software. * For more information on the license, see COPYING. * For more information on free software, see <https://www.gnu.org/philosophy/free-sw.en.html>. */ #include "modulemd.h" #include <glib.h> enum { SL_PROP_0, SL_PROP_EOL, SL_PROP_NAME, SL_N_PROPERTIES }; static GParamSpec *servicelevel_properties[SL_N_PROPERTIES] = { NULL, }; struct _ModulemdServiceLevel { GObject parent_instance; GDate *eol; gchar *name; }; G_DEFINE_TYPE (ModulemdServiceLevel, modulemd_servicelevel, G_TYPE_OBJECT) void modulemd_servicelevel_set_eol (ModulemdServiceLevel *self, const GDate *date) { g_return_if_fail (MODULEMD_IS_SERVICELEVEL (self)); g_return_if_fail (!date || g_date_valid (date)); if (!date || !g_date_valid (date)) { g_date_clear (self->eol, 1); g_object_notify_by_pspec (G_OBJECT (self), servicelevel_properties[SL_PROP_EOL]); return; } if (!g_date_valid (self->eol) || g_date_compare (date, self->eol) != 0) { /* Date is changing. Update it */ g_date_set_year (self->eol, g_date_get_year (date)); g_date_set_month (self->eol, g_date_get_month (date)); g_date_set_day (self->eol, g_date_get_day (date)); } g_object_notify_by_pspec (G_OBJECT (self), servicelevel_properties[SL_PROP_EOL]); } const GDate * modulemd_servicelevel_get_eol (ModulemdServiceLevel *self) { return modulemd_servicelevel_peek_eol (self); } const GDate * modulemd_servicelevel_peek_eol (ModulemdServiceLevel *self) { g_return_val_if_fail (MODULEMD_IS_SERVICELEVEL (self), NULL); if (!g_date_valid (self->eol)) { return NULL; } return self->eol; } GDate * modulemd_servicelevel_dup_eol (ModulemdServiceLevel *self) { g_return_val_if_fail (MODULEMD_IS_SERVICELEVEL (self), NULL); if (!g_date_valid (self->eol)) { return NULL; } return g_date_new_dmy (g_date_get_day (self->eol), g_date_get_month (self->eol), g_date_get_year (self->eol)); } void modulemd_servicelevel_set_name (ModulemdServiceLevel *self, const gchar *name) { g_return_if_fail (MODULEMD_IS_SERVICELEVEL (self)); g_clear_pointer (&self->name, g_free); if (name) { self->name = g_strdup (name); } g_object_notify_by_pspec (G_OBJECT (self), servicelevel_properties[SL_PROP_NAME]); } const gchar * modulemd_servicelevel_get_name (ModulemdServiceLevel *self) { return modulemd_servicelevel_peek_name (self); } const gchar * modulemd_servicelevel_peek_name (ModulemdServiceLevel *self) { g_return_val_if_fail (MODULEMD_IS_SERVICELEVEL (self), NULL); if (!self->name) { g_warning ("Servicelevel name requested, but has not been set"); } return self->name; } gchar * modulemd_servicelevel_dup_name (ModulemdServiceLevel *self) { g_return_val_if_fail (MODULEMD_IS_SERVICELEVEL (self), NULL); if (!self->name) { g_warning ("Servicelevel name requested, but has not been set"); return NULL; } return g_strdup (self->name); } ModulemdServiceLevel * modulemd_servicelevel_copy (ModulemdServiceLevel *self) { ModulemdServiceLevel *new_sl = NULL; if (!self) return NULL; g_return_val_if_fail (MODULEMD_IS_SERVICELEVEL (self), NULL); new_sl = modulemd_servicelevel_new (); modulemd_servicelevel_set_eol (new_sl, modulemd_servicelevel_peek_eol (self)); modulemd_servicelevel_set_name (new_sl, modulemd_servicelevel_peek_name (self)); return new_sl; } static void modulemd_servicelevel_set_property (GObject *gobject, guint property_id, const GValue *value, GParamSpec *pspec) { ModulemdServiceLevel *self = MODULEMD_SERVICELEVEL (gobject); switch (property_id) { case SL_PROP_EOL: modulemd_servicelevel_set_eol (self, g_value_get_boxed (value)); break; case SL_PROP_NAME: modulemd_servicelevel_set_name (self, g_value_get_string (value)); break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, property_id, pspec); break; } } static void modulemd_servicelevel_get_property (GObject *gobject, guint property_id, GValue *value, GParamSpec *pspec) { ModulemdServiceLevel *self = MODULEMD_SERVICELEVEL (gobject); switch (property_id) { case SL_PROP_EOL: g_value_set_boxed (value, modulemd_servicelevel_peek_eol (self)); break; case SL_PROP_NAME: g_value_set_string (value, modulemd_servicelevel_peek_name (self)); break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, property_id, pspec); break; } } static void modulemd_servicelevel_finalize (GObject *gobject) { ModulemdServiceLevel *self = (ModulemdServiceLevel *)gobject; g_clear_pointer (&self->eol, g_date_free); g_clear_pointer (&self->name, g_free); G_OBJECT_CLASS (modulemd_servicelevel_parent_class)->finalize (gobject); } static void modulemd_servicelevel_class_init (ModulemdServiceLevelClass *klass) { GObjectClass *object_class = G_OBJECT_CLASS (klass); object_class->set_property = modulemd_servicelevel_set_property; object_class->get_property = modulemd_servicelevel_get_property; object_class->finalize = modulemd_servicelevel_finalize; servicelevel_properties[SL_PROP_EOL] = g_param_spec_boxed ("eol", "End of Life", "An ISO-8601 compatible YYYY-MM-DD value " "representing the end-of-life date of this service " "level.", G_TYPE_DATE, G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS); servicelevel_properties[SL_PROP_NAME] = g_param_spec_string ("name", "Name", "A human-readable name for this servicelevel", NULL, G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS); g_object_class_install_properties ( object_class, SL_N_PROPERTIES, servicelevel_properties); } static void modulemd_servicelevel_init (ModulemdServiceLevel *self) { self->eol = g_date_new (); } ModulemdServiceLevel * modulemd_servicelevel_new (void) { return g_object_new (MODULEMD_TYPE_SERVICELEVEL, NULL); }