mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2024-09-30 19:17:34 +00:00
GtkRadioMenuItem: Move public members to private structure
This commit is contained in:
parent
ec4c06105d
commit
133502d798
@ -33,6 +33,11 @@
|
|||||||
#include "gtkintl.h"
|
#include "gtkintl.h"
|
||||||
|
|
||||||
|
|
||||||
|
struct _GtkRadioMenuItemPriv
|
||||||
|
{
|
||||||
|
GSList *group;
|
||||||
|
};
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
PROP_0,
|
PROP_0,
|
||||||
PROP_GROUP
|
PROP_GROUP
|
||||||
@ -111,35 +116,38 @@ void
|
|||||||
gtk_radio_menu_item_set_group (GtkRadioMenuItem *radio_menu_item,
|
gtk_radio_menu_item_set_group (GtkRadioMenuItem *radio_menu_item,
|
||||||
GSList *group)
|
GSList *group)
|
||||||
{
|
{
|
||||||
|
GtkRadioMenuItemPriv *priv;
|
||||||
GtkWidget *old_group_singleton = NULL;
|
GtkWidget *old_group_singleton = NULL;
|
||||||
GtkWidget *new_group_singleton = NULL;
|
GtkWidget *new_group_singleton = NULL;
|
||||||
|
|
||||||
g_return_if_fail (GTK_IS_RADIO_MENU_ITEM (radio_menu_item));
|
g_return_if_fail (GTK_IS_RADIO_MENU_ITEM (radio_menu_item));
|
||||||
g_return_if_fail (!g_slist_find (group, radio_menu_item));
|
g_return_if_fail (!g_slist_find (group, radio_menu_item));
|
||||||
|
|
||||||
if (radio_menu_item->group)
|
priv = radio_menu_item->priv;
|
||||||
|
|
||||||
|
if (priv->group)
|
||||||
{
|
{
|
||||||
GSList *slist;
|
GSList *slist;
|
||||||
|
|
||||||
radio_menu_item->group = g_slist_remove (radio_menu_item->group, radio_menu_item);
|
priv->group = g_slist_remove (priv->group, radio_menu_item);
|
||||||
|
|
||||||
if (radio_menu_item->group && !radio_menu_item->group->next)
|
if (priv->group && !priv->group->next)
|
||||||
old_group_singleton = g_object_ref (radio_menu_item->group->data);
|
old_group_singleton = g_object_ref (priv->group->data);
|
||||||
|
|
||||||
for (slist = radio_menu_item->group; slist; slist = slist->next)
|
for (slist = priv->group; slist; slist = slist->next)
|
||||||
{
|
{
|
||||||
GtkRadioMenuItem *tmp_item;
|
GtkRadioMenuItem *tmp_item;
|
||||||
|
|
||||||
tmp_item = slist->data;
|
tmp_item = slist->data;
|
||||||
|
|
||||||
tmp_item->group = radio_menu_item->group;
|
tmp_item->priv->group = priv->group;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (group && !group->next)
|
if (group && !group->next)
|
||||||
new_group_singleton = g_object_ref (group->data);
|
new_group_singleton = g_object_ref (group->data);
|
||||||
|
|
||||||
radio_menu_item->group = g_slist_prepend (group, radio_menu_item);
|
priv->group = g_slist_prepend (group, radio_menu_item);
|
||||||
|
|
||||||
if (group)
|
if (group)
|
||||||
{
|
{
|
||||||
@ -151,7 +159,7 @@ gtk_radio_menu_item_set_group (GtkRadioMenuItem *radio_menu_item,
|
|||||||
|
|
||||||
tmp_item = slist->data;
|
tmp_item = slist->data;
|
||||||
|
|
||||||
tmp_item->group = radio_menu_item->group;
|
tmp_item->priv->group = priv->group;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -321,7 +329,7 @@ gtk_radio_menu_item_get_group (GtkRadioMenuItem *radio_menu_item)
|
|||||||
{
|
{
|
||||||
g_return_val_if_fail (GTK_IS_RADIO_MENU_ITEM (radio_menu_item), NULL);
|
g_return_val_if_fail (GTK_IS_RADIO_MENU_ITEM (radio_menu_item), NULL);
|
||||||
|
|
||||||
return radio_menu_item->group;
|
return radio_menu_item->priv->group;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -378,12 +386,21 @@ gtk_radio_menu_item_class_init (GtkRadioMenuItemClass *klass)
|
|||||||
NULL, NULL,
|
NULL, NULL,
|
||||||
_gtk_marshal_VOID__VOID,
|
_gtk_marshal_VOID__VOID,
|
||||||
G_TYPE_NONE, 0);
|
G_TYPE_NONE, 0);
|
||||||
|
|
||||||
|
g_type_class_add_private (klass, sizeof (GtkRadioMenuItemPriv));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gtk_radio_menu_item_init (GtkRadioMenuItem *radio_menu_item)
|
gtk_radio_menu_item_init (GtkRadioMenuItem *radio_menu_item)
|
||||||
{
|
{
|
||||||
radio_menu_item->group = g_slist_prepend (NULL, radio_menu_item);
|
GtkRadioMenuItemPriv *priv;
|
||||||
|
|
||||||
|
radio_menu_item->priv = G_TYPE_INSTANCE_GET_PRIVATE (radio_menu_item,
|
||||||
|
GTK_TYPE_RADIO_MENU_ITEM,
|
||||||
|
GtkRadioMenuItemPriv);
|
||||||
|
priv = radio_menu_item->priv;
|
||||||
|
|
||||||
|
priv->group = g_slist_prepend (NULL, radio_menu_item);
|
||||||
gtk_check_menu_item_set_draw_as_radio (GTK_CHECK_MENU_ITEM (radio_menu_item), TRUE);
|
gtk_check_menu_item_set_draw_as_radio (GTK_CHECK_MENU_ITEM (radio_menu_item), TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -391,30 +408,30 @@ static void
|
|||||||
gtk_radio_menu_item_destroy (GtkObject *object)
|
gtk_radio_menu_item_destroy (GtkObject *object)
|
||||||
{
|
{
|
||||||
GtkRadioMenuItem *radio_menu_item = GTK_RADIO_MENU_ITEM (object);
|
GtkRadioMenuItem *radio_menu_item = GTK_RADIO_MENU_ITEM (object);
|
||||||
|
GtkRadioMenuItemPriv *priv = radio_menu_item->priv;
|
||||||
GtkWidget *old_group_singleton = NULL;
|
GtkWidget *old_group_singleton = NULL;
|
||||||
GtkRadioMenuItem *tmp_menu_item;
|
GtkRadioMenuItem *tmp_menu_item;
|
||||||
GSList *tmp_list;
|
GSList *tmp_list;
|
||||||
gboolean was_in_group;
|
gboolean was_in_group;
|
||||||
|
|
||||||
was_in_group = radio_menu_item->group && radio_menu_item->group->next;
|
was_in_group = priv->group && priv->group->next;
|
||||||
|
|
||||||
radio_menu_item->group = g_slist_remove (radio_menu_item->group,
|
priv->group = g_slist_remove (priv->group, radio_menu_item);
|
||||||
radio_menu_item);
|
if (priv->group && !priv->group->next)
|
||||||
if (radio_menu_item->group && !radio_menu_item->group->next)
|
old_group_singleton = priv->group->data;
|
||||||
old_group_singleton = radio_menu_item->group->data;
|
|
||||||
|
|
||||||
tmp_list = radio_menu_item->group;
|
tmp_list = priv->group;
|
||||||
|
|
||||||
while (tmp_list)
|
while (tmp_list)
|
||||||
{
|
{
|
||||||
tmp_menu_item = tmp_list->data;
|
tmp_menu_item = tmp_list->data;
|
||||||
tmp_list = tmp_list->next;
|
tmp_list = tmp_list->next;
|
||||||
|
|
||||||
tmp_menu_item->group = radio_menu_item->group;
|
tmp_menu_item->priv->group = priv->group;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* this radio menu item is no longer in the group */
|
/* this radio menu item is no longer in the group */
|
||||||
radio_menu_item->group = NULL;
|
priv->group = NULL;
|
||||||
|
|
||||||
if (old_group_singleton)
|
if (old_group_singleton)
|
||||||
g_signal_emit (old_group_singleton, group_changed_signal, 0);
|
g_signal_emit (old_group_singleton, group_changed_signal, 0);
|
||||||
@ -428,6 +445,7 @@ static void
|
|||||||
gtk_radio_menu_item_activate (GtkMenuItem *menu_item)
|
gtk_radio_menu_item_activate (GtkMenuItem *menu_item)
|
||||||
{
|
{
|
||||||
GtkRadioMenuItem *radio_menu_item = GTK_RADIO_MENU_ITEM (menu_item);
|
GtkRadioMenuItem *radio_menu_item = GTK_RADIO_MENU_ITEM (menu_item);
|
||||||
|
GtkRadioMenuItemPriv *priv = radio_menu_item->priv;
|
||||||
GtkCheckMenuItem *check_menu_item = GTK_CHECK_MENU_ITEM (menu_item);
|
GtkCheckMenuItem *check_menu_item = GTK_CHECK_MENU_ITEM (menu_item);
|
||||||
GtkCheckMenuItem *tmp_menu_item;
|
GtkCheckMenuItem *tmp_menu_item;
|
||||||
GtkAction *action;
|
GtkAction *action;
|
||||||
@ -445,7 +463,7 @@ gtk_radio_menu_item_activate (GtkMenuItem *menu_item)
|
|||||||
if (active)
|
if (active)
|
||||||
{
|
{
|
||||||
tmp_menu_item = NULL;
|
tmp_menu_item = NULL;
|
||||||
tmp_list = radio_menu_item->group;
|
tmp_list = priv->group;
|
||||||
|
|
||||||
while (tmp_list)
|
while (tmp_list)
|
||||||
{
|
{
|
||||||
@ -470,7 +488,7 @@ gtk_radio_menu_item_activate (GtkMenuItem *menu_item)
|
|||||||
toggled = TRUE;
|
toggled = TRUE;
|
||||||
gtk_check_menu_item_set_active (check_menu_item, !active);
|
gtk_check_menu_item_set_active (check_menu_item, !active);
|
||||||
|
|
||||||
tmp_list = radio_menu_item->group;
|
tmp_list = priv->group;
|
||||||
while (tmp_list)
|
while (tmp_list)
|
||||||
{
|
{
|
||||||
tmp_menu_item = tmp_list->data;
|
tmp_menu_item = tmp_list->data;
|
||||||
|
@ -46,13 +46,15 @@ G_BEGIN_DECLS
|
|||||||
|
|
||||||
|
|
||||||
typedef struct _GtkRadioMenuItem GtkRadioMenuItem;
|
typedef struct _GtkRadioMenuItem GtkRadioMenuItem;
|
||||||
|
typedef struct _GtkRadioMenuItemPriv GtkRadioMenuItemPriv;
|
||||||
typedef struct _GtkRadioMenuItemClass GtkRadioMenuItemClass;
|
typedef struct _GtkRadioMenuItemClass GtkRadioMenuItemClass;
|
||||||
|
|
||||||
struct _GtkRadioMenuItem
|
struct _GtkRadioMenuItem
|
||||||
{
|
{
|
||||||
GtkCheckMenuItem check_menu_item;
|
GtkCheckMenuItem check_menu_item;
|
||||||
|
|
||||||
GSList *GSEAL (group);
|
/* <private> */
|
||||||
|
GtkRadioMenuItemPriv *priv;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _GtkRadioMenuItemClass
|
struct _GtkRadioMenuItemClass
|
||||||
|
Loading…
Reference in New Issue
Block a user