1 /* gtkradiotoolbutton.c
3 * Copyright (C) 2002 Anders Carlsson <andersca@gnome.og>
4 * Copyright (C) 2002 James Henstridge <james@daa.com.au>
5 * Copyright (C) 2003 Soeren Sandmann <sandmann@daimi.au.dk>
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version.
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the
19 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
20 * Boston, MA 02111-1307, USA.
24 #include "gtkradiotoolbutton.h"
25 #include "gtkradiobutton.h"
27 #include "gtkprivate.h"
35 static void gtk_radio_tool_button_set_property (GObject *object,
40 G_DEFINE_TYPE (GtkRadioToolButton, gtk_radio_tool_button, GTK_TYPE_TOGGLE_TOOL_BUTTON)
43 gtk_radio_tool_button_class_init (GtkRadioToolButtonClass *klass)
45 GObjectClass *object_class;
46 GtkToolButtonClass *toolbutton_class;
48 object_class = (GObjectClass *)klass;
49 toolbutton_class = (GtkToolButtonClass *)klass;
51 object_class->set_property = gtk_radio_tool_button_set_property;
53 toolbutton_class->button_type = GTK_TYPE_RADIO_BUTTON;
56 * GtkRadioToolButton:group:
58 * Sets a new group for a radio tool button.
62 g_object_class_install_property (object_class,
64 g_param_spec_object ("group",
66 P_("The radio tool button whose group this button belongs to."),
67 GTK_TYPE_RADIO_TOOL_BUTTON,
73 gtk_radio_tool_button_init (GtkRadioToolButton *button)
75 GtkToolButton *tool_button = GTK_TOOL_BUTTON (button);
76 gtk_toggle_button_set_mode (GTK_TOGGLE_BUTTON (_gtk_tool_button_get_button (tool_button)), FALSE);
80 gtk_radio_tool_button_set_property (GObject *object,
85 GtkRadioToolButton *button;
87 button = GTK_RADIO_TOOL_BUTTON (object);
93 GtkRadioToolButton *arg;
95 if (G_VALUE_HOLDS_OBJECT (value))
97 arg = GTK_RADIO_TOOL_BUTTON (g_value_get_object (value));
99 slist = gtk_radio_tool_button_get_group (arg);
100 gtk_radio_tool_button_set_group (button, slist);
105 G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
111 * gtk_radio_tool_button_new:
112 * @group: (allow-none): An existing radio button group, or %NULL if you are creating a new group
114 * Creates a new #GtkRadioToolButton, adding it to @group.
116 * Return value: The new #GtkRadioToolButton
121 gtk_radio_tool_button_new (GSList *group)
123 GtkRadioToolButton *button;
125 button = g_object_new (GTK_TYPE_RADIO_TOOL_BUTTON,
128 gtk_radio_tool_button_set_group (button, group);
130 return GTK_TOOL_ITEM (button);
134 * gtk_radio_tool_button_new_from_stock:
135 * @group: (allow-none): an existing radio button group, or %NULL if you are creating a new group
136 * @stock_id: the name of a stock item
138 * Creates a new #GtkRadioToolButton, adding it to @group.
139 * The new #GtkRadioToolButton will contain an icon and label from the
140 * stock item indicated by @stock_id.
142 * Return value: The new #GtkRadioToolItem
147 gtk_radio_tool_button_new_from_stock (GSList *group,
148 const gchar *stock_id)
150 GtkRadioToolButton *button;
152 g_return_val_if_fail (stock_id != NULL, NULL);
154 button = g_object_new (GTK_TYPE_RADIO_TOOL_BUTTON,
155 "stock-id", stock_id,
159 gtk_radio_tool_button_set_group (button, group);
161 return GTK_TOOL_ITEM (button);
165 * gtk_radio_tool_button_new_from_widget:
166 * @group: An existing #GtkRadioToolButton
168 * Creates a new #GtkRadioToolButton adding it to the same group as @gruup
170 * Return value: The new #GtkRadioToolButton
175 gtk_radio_tool_button_new_from_widget (GtkRadioToolButton *group)
179 g_return_val_if_fail (GTK_IS_RADIO_TOOL_BUTTON (group), NULL);
182 list = gtk_radio_tool_button_get_group (GTK_RADIO_TOOL_BUTTON (group));
184 return gtk_radio_tool_button_new (list);
188 * gtk_radio_tool_button_new_with_stock_from_widget:
189 * @group: An existing #GtkRadioToolButton.
190 * @stock_id: the name of a stock item
192 * Creates a new #GtkRadioToolButton adding it to the same group as @group.
193 * The new #GtkRadioToolButton will contain an icon and label from the
194 * stock item indicated by @stock_id.
196 * Return value: A new #GtkRadioToolButton
201 gtk_radio_tool_button_new_with_stock_from_widget (GtkRadioToolButton *group,
202 const gchar *stock_id)
206 g_return_val_if_fail (GTK_IS_RADIO_TOOL_BUTTON (group), NULL);
209 list = gtk_radio_tool_button_get_group (group);
211 return gtk_radio_tool_button_new_from_stock (list, stock_id);
214 static GtkRadioButton *
215 get_radio_button (GtkRadioToolButton *button)
217 return GTK_RADIO_BUTTON (_gtk_tool_button_get_button (GTK_TOOL_BUTTON (button)));
221 * gtk_radio_tool_button_get_group:
222 * @button: a #GtkRadioToolButton
224 * Returns the radio button group @button belongs to.
226 * Return value: The group @button belongs to.
231 gtk_radio_tool_button_get_group (GtkRadioToolButton *button)
233 g_return_val_if_fail (GTK_IS_RADIO_TOOL_BUTTON (button), NULL);
235 return gtk_radio_button_get_group (get_radio_button (button));
239 * gtk_radio_tool_button_set_group:
240 * @button: a #GtkRadioToolButton
241 * @group: an existing radio button group
243 * Adds @button to @group, removing it from the group it belonged to before.
248 gtk_radio_tool_button_set_group (GtkRadioToolButton *button,
251 g_return_if_fail (GTK_IS_RADIO_TOOL_BUTTON (button));
253 gtk_radio_button_set_group (get_radio_button (button), group);