1 /* 2 * This file is part of d-dazzle. 3 * 4 * d-dazzle is free software; you can redistribute it and/or modify 5 * it under the terms of the GNU Lesser General Public License 6 * as published by the Free Software Foundation; either version 3 7 * of the License, or (at your option) any later version, with 8 * some exceptions, please read the COPYING file. 9 * 10 * d-dazzle is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU Lesser General Public License for more details. 14 * 15 * You should have received a copy of the GNU Lesser General Public License 16 * along with d-dazzle; if not, write to the Free Software 17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA 18 */ 19 module dazzle.WidgetActionGroup; 20 21 private import dazzle.c.functions; 22 public import dazzle.c.types; 23 private import gio.ActionGroupIF; 24 private import gio.ActionGroupT; 25 private import glib.ConstructionException; 26 private import glib.Str; 27 private import gobject.ObjectG; 28 private import gtk.Widget; 29 30 31 /** */ 32 public class WidgetActionGroup : ObjectG, ActionGroupIF 33 { 34 /** the main Gtk struct */ 35 protected DzlWidgetActionGroup* dzlWidgetActionGroup; 36 37 /** Get the main Gtk struct */ 38 public DzlWidgetActionGroup* getWidgetActionGroupStruct(bool transferOwnership = false) 39 { 40 if (transferOwnership) 41 ownedRef = false; 42 return dzlWidgetActionGroup; 43 } 44 45 /** the main Gtk struct as a void* */ 46 protected override void* getStruct() 47 { 48 return cast(void*)dzlWidgetActionGroup; 49 } 50 51 /** 52 * Sets our main struct and passes it to the parent class. 53 */ 54 public this (DzlWidgetActionGroup* dzlWidgetActionGroup, bool ownedRef = false) 55 { 56 this.dzlWidgetActionGroup = dzlWidgetActionGroup; 57 super(cast(GObject*)dzlWidgetActionGroup, ownedRef); 58 } 59 60 // add the ActionGroup capabilities 61 mixin ActionGroupT!(DzlWidgetActionGroup); 62 63 64 /** */ 65 public static GType getType() 66 { 67 return dzl_widget_action_group_get_type(); 68 } 69 70 /** 71 * Helper function to create an #DzlWidgetActionGroup and attach 72 * it to @widget using the group name @group_name. 73 * 74 * Params: 75 * widget = A #GtkWidget 76 * groupName = the group name to use for the action group 77 */ 78 public static void attach(Widget widget, string groupName) 79 { 80 dzl_widget_action_group_attach((widget is null) ? null : widget.getWidgetStruct(), Str.toStringz(groupName)); 81 } 82 83 /** 84 * Returns: An #DzlWidgetActionGroup. 85 * 86 * Throws: ConstructionException GTK+ fails to create the object. 87 */ 88 public this(Widget widget) 89 { 90 auto p = dzl_widget_action_group_new((widget is null) ? null : widget.getWidgetStruct()); 91 92 if(p is null) 93 { 94 throw new ConstructionException("null returned by new"); 95 } 96 97 this(cast(DzlWidgetActionGroup*) p, true); 98 } 99 100 /** */ 101 public void setActionEnabled(string actionName, bool enabled) 102 { 103 dzl_widget_action_group_set_action_enabled(dzlWidgetActionGroup, Str.toStringz(actionName), enabled); 104 } 105 }