1 /*
2  * This file is part of gtkD.
3  *
4  * gtkD 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  * gtkD 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 gtkD; if not, write to the Free Software
17  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA
18  */
19 
20 // generated automatically - do not change
21 // find conversion definition on APILookup.txt
22 // implement new conversion functionalities on the wrap.utils pakage
23 
24 
25 module peas.ConfigurableT;
26 
27 public  import gobject.ObjectG;
28 public  import gtk.Widget;
29 public  import peasc.peas;
30 public  import peasc.peastypes;
31 
32 
33 /**
34  * Interface for configurable plugins.
35  */
36 public template ConfigurableT(TStruct)
37 {
38 	/** Get the main Gtk struct */
39 	public PeasGtkConfigurable* getConfigurableStruct()
40 	{
41 		return cast(PeasGtkConfigurable*)getStruct();
42 	}
43 
44 
45 	/**
46 	 * Creates the configure widget for the plugin. The returned widget
47 	 * should allow configuring all the relevant aspects of the plugin, and should
48 	 * allow instant-apply, as promoted by the Gnome Human Interface Guidelines.
49 	 *
50 	 * #PeasGtkPluginManager will embed the returned widget into a dialog box,
51 	 * but you shouldn't take this behaviour for granted as other implementations
52 	 * of a plugin manager UI might do otherwise.
53 	 *
54 	 * This method should always return a valid #GtkWidget instance, never %NULL.
55 	 *
56 	 * Return: A #GtkWidget used for configuration.
57 	 */
58 	public Widget createConfigureWidget()
59 	{
60 		auto p = peas_gtk_configurable_create_configure_widget(getConfigurableStruct());
61 		
62 		if(p is null)
63 		{
64 			return null;
65 		}
66 		
67 		return ObjectG.getDObject!(Widget)(cast(GtkWidget*) p, true);
68 	}
69 }