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 gio.DBusObjectIF;
26 
27 private import gio.DBusInterface;
28 private import gio.DBusInterfaceIF;
29 private import glib.ListG;
30 private import glib.Str;
31 private import gobject.ObjectG;
32 private import gobject.Signals;
33 public  import gtkc.gdktypes;
34 private import gtkc.gio;
35 public  import gtkc.giotypes;
36 
37 
38 /**
39  * The #GDBusObject type is the base type for D-Bus objects on both
40  * the service side (see #GDBusObjectSkeleton) and the client side
41  * (see #GDBusObjectProxy). It is essentially just a container of
42  * interfaces.
43  */
44 public interface DBusObjectIF{
45 	/** Get the main Gtk struct */
46 	public GDBusObject* getDBusObjectStruct();
47 
48 	/** the main Gtk struct as a void* */
49 	protected void* getStruct();
50 
51 	/**
52 	 */
53 
54 	/**
55 	 * Gets the D-Bus interface with name @interface_name associated with
56 	 * @object, if any.
57 	 *
58 	 * Params:
59 	 *     interfaceName = A D-Bus interface name.
60 	 *
61 	 * Return: %NULL if not found, otherwise a
62 	 *     #GDBusInterface that must be freed with g_object_unref().
63 	 *
64 	 * Since: 2.30
65 	 */
66 	public DBusInterfaceIF getInterface(string interfaceName);
67 
68 	/**
69 	 * Gets the D-Bus interfaces associated with @object.
70 	 *
71 	 * Return: A list of #GDBusInterface instances.
72 	 *     The returned list must be freed by g_list_free() after each element has been freed
73 	 *     with g_object_unref().
74 	 *
75 	 * Since: 2.30
76 	 */
77 	public ListG getInterfaces();
78 
79 	/**
80 	 * Gets the object path for @object.
81 	 *
82 	 * Return: A string owned by @object. Do not free.
83 	 *
84 	 * Since: 2.30
85 	 */
86 	public string getObjectPath();
87 	@property void delegate(DBusInterfaceIF, DBusObjectIF)[] onInterfaceAddedListeners();
88 	/**
89 	 * Emitted when @interface is added to @object.
90 	 *
91 	 * Params:
92 	 *     iface = The #GDBusInterface that was added.
93 	 *
94 	 * Since: 2.30
95 	 */
96 	void addOnInterfaceAdded(void delegate(DBusInterfaceIF, DBusObjectIF) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0);
97 
98 	@property void delegate(DBusInterfaceIF, DBusObjectIF)[] onInterfaceRemovedListeners();
99 	/**
100 	 * Emitted when @interface is removed from @object.
101 	 *
102 	 * Params:
103 	 *     iface = The #GDBusInterface that was removed.
104 	 *
105 	 * Since: 2.30
106 	 */
107 	void addOnInterfaceRemoved(void delegate(DBusInterfaceIF, DBusObjectIF) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0);
108 
109 }