Blob Blame History Raw
// SPDX-License-Identifier: GPL-2.0+
/*
 * Copyright (C) 2013 Red Hat, Inc.
 */

/**
 * SECTION:nmt-editor-page:
 * @short_description: An #NmtEditor "page"
 *
 * #NmtEditorPage is the abstract base class for #NmtEditor "pages".
 * A "page" is a set of related #NmtEditorSections.
 */

#include "nm-default.h"

#include "nmt-editor-page.h"

G_DEFINE_ABSTRACT_TYPE (NmtEditorPage, nmt_editor_page, G_TYPE_OBJECT)

#define NMT_EDITOR_PAGE_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), NMT_TYPE_EDITOR_PAGE, NmtEditorPagePrivate))

typedef struct {
	NMConnection *connection;
	GSList *sections;

} NmtEditorPagePrivate;

enum {
	PROP_0,

	PROP_CONNECTION,

	LAST_PROP
};

static void
nmt_editor_page_init (NmtEditorPage *page)
{
}

static void
nmt_editor_page_finalize (GObject *object)
{
	NmtEditorPagePrivate *priv = NMT_EDITOR_PAGE_GET_PRIVATE (object);

	g_clear_object (&priv->connection);
	g_slist_free_full (priv->sections, g_object_unref);

	G_OBJECT_CLASS (nmt_editor_page_parent_class)->finalize (object);
}

/**
 * nmt_editor_page_get_connection:
 * @page: the #NmtEditorPage
 *
 * Gets the page's #NMConnection.
 *
 * Returns: (transfer none): the page's #NMConnection.
 */
NMConnection *
nmt_editor_page_get_connection (NmtEditorPage *page)
{
	NmtEditorPagePrivate *priv = NMT_EDITOR_PAGE_GET_PRIVATE (page);

	return priv->connection;
}

/**
 * nmt_editor_page_get_sections:
 * @page: the #NmtEditorPage
 *
 * Gets the page's list of sections to display.
 *
 * Returns: (transfer none): the list of sections; this is the internal list
 * used by the page and must not be modified or freed.
 */
GSList *
nmt_editor_page_get_sections (NmtEditorPage *page)
{
	NmtEditorPagePrivate *priv = NMT_EDITOR_PAGE_GET_PRIVATE (page);

	return priv->sections;
}

/**
 * nmt_editor_page_add_section:
 * @page: the #NmtEditorPage
 * @section: the #NmtEditorSection
 *
 * Adds a section to the page. This should only be called by #NmtEditorPage
 * subclasses.
 */
void
nmt_editor_page_add_section (NmtEditorPage *page,
                             NmtEditorSection *section)
{
	NmtEditorPagePrivate *priv = NMT_EDITOR_PAGE_GET_PRIVATE (page);

	priv->sections = g_slist_append (priv->sections, g_object_ref_sink (section));
}

/**
 * nmt_editor_page_saved:
 * @page: the #NmtEditorPage
 *
 * This method is called when the user saves the connection. It gives
 * the page a chance to do save its data outside the connections (such as
 * recommit the slave connections).
 */
void
nmt_editor_page_saved (NmtEditorPage *page)
{
	NmtEditorPageClass *editor_page_class = NMT_EDITOR_PAGE_GET_CLASS (page);

	if (editor_page_class->saved)
		editor_page_class->saved (page);
}

static void
nmt_editor_page_set_property (GObject      *object,
                              guint         prop_id,
                              const GValue *value,
                              GParamSpec   *pspec)
{
	NmtEditorPagePrivate *priv = NMT_EDITOR_PAGE_GET_PRIVATE (object);

	switch (prop_id) {
	case PROP_CONNECTION:
		priv->connection = g_value_dup_object (value);
		break;
	default:
		G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
		break;
	}
}

static void
nmt_editor_page_get_property (GObject    *object,
                              guint       prop_id,
                              GValue     *value,
                              GParamSpec *pspec)
{
	NmtEditorPagePrivate *priv = NMT_EDITOR_PAGE_GET_PRIVATE (object);

	switch (prop_id) {
	case PROP_CONNECTION:
		g_value_set_object (value, priv->connection);
		break;
	default:
		G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
		break;
	}
}

static void
nmt_editor_page_class_init (NmtEditorPageClass *page_class)
{
	GObjectClass *object_class = G_OBJECT_CLASS (page_class);

	g_type_class_add_private (page_class, sizeof (NmtEditorPagePrivate));

	/* virtual methods */
	object_class->set_property = nmt_editor_page_set_property;
	object_class->get_property = nmt_editor_page_get_property;
	object_class->finalize     = nmt_editor_page_finalize;

	/* properties */

	/**
	 * NmtEditorPage:connection:
	 *
	 * The page's #NMConnection.
	 */
	g_object_class_install_property
		(object_class, PROP_CONNECTION,
		 g_param_spec_object ("connection", "", "",
		                      NM_TYPE_CONNECTION,
		                      G_PARAM_READWRITE |
		                      G_PARAM_CONSTRUCT_ONLY |
		                      G_PARAM_STATIC_STRINGS));
}