Optional autogen.sh flag --enable-kdbus-transport added allowing to compile with...
[platform/upstream/dbus.git] / dbus / dbus-message.h
1 /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
2 /* dbus-message.h DBusMessage object
3  *
4  * Copyright (C) 2002, 2003, 2005 Red Hat Inc.
5  *
6  * Licensed under the Academic Free License version 2.1
7  * 
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  * 
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
21  *
22  */
23 #if !defined (DBUS_INSIDE_DBUS_H) && !defined (DBUS_COMPILATION)
24 #error "Only <dbus/dbus.h> can be included directly, this file may disappear or change contents."
25 #endif
26
27 #ifndef DBUS_MESSAGE_H
28 #define DBUS_MESSAGE_H
29
30 #include <dbus/dbus-macros.h>
31 #include <dbus/dbus-types.h>
32 #include <dbus/dbus-arch-deps.h>
33 #include <dbus/dbus-memory.h>
34 #include <dbus/dbus-errors.h>
35 #include <stdarg.h>
36
37 DBUS_BEGIN_DECLS
38
39 /**
40  * @addtogroup DBusMessage
41  * @{
42  */
43
44 typedef struct DBusMessage DBusMessage;
45 /** Opaque type representing a message iterator. Can be copied by value, and contains no allocated memory so never needs to be freed and can be allocated on the stack. */
46 typedef struct DBusMessageIter DBusMessageIter;
47
48 /**
49  * DBusMessageIter struct; contains no public fields. 
50  */
51 struct DBusMessageIter
52
53   void *dummy1;         /**< Don't use this */
54   void *dummy2;         /**< Don't use this */
55   dbus_uint32_t dummy3; /**< Don't use this */
56   int dummy4;           /**< Don't use this */
57   int dummy5;           /**< Don't use this */
58   int dummy6;           /**< Don't use this */
59   int dummy7;           /**< Don't use this */
60   int dummy8;           /**< Don't use this */
61   int dummy9;           /**< Don't use this */
62   int dummy10;          /**< Don't use this */
63   int dummy11;          /**< Don't use this */
64   int pad1;             /**< Don't use this */
65   int pad2;             /**< Don't use this */
66   void *pad3;           /**< Don't use this */
67 };
68
69 DBUS_EXPORT
70 DBusMessage* dbus_message_new               (int          message_type);
71 DBUS_EXPORT
72 DBusMessage* dbus_message_new_method_call   (const char  *bus_name,
73                                              const char  *path,
74                                              const char  *iface,
75                                              const char  *method);
76 DBUS_EXPORT
77 DBusMessage* dbus_message_new_method_return (DBusMessage *method_call);
78 DBUS_EXPORT
79 DBusMessage* dbus_message_new_signal        (const char  *path,
80                                              const char  *iface,
81                                              const char  *name);
82 DBUS_EXPORT
83 DBusMessage* dbus_message_new_error         (DBusMessage *reply_to,
84                                              const char  *error_name,
85                                              const char  *error_message);
86 DBUS_EXPORT
87 DBusMessage* dbus_message_new_error_printf  (DBusMessage *reply_to,
88                                              const char  *error_name,
89                                              const char  *error_format,
90                                              ...);
91
92 DBUS_EXPORT
93 DBusMessage* dbus_message_copy              (const DBusMessage *message);
94
95 DBUS_EXPORT
96 DBusMessage*  dbus_message_ref              (DBusMessage   *message);
97 DBUS_EXPORT
98 void          dbus_message_unref            (DBusMessage   *message);
99 DBUS_EXPORT
100 int           dbus_message_get_type         (DBusMessage   *message);
101 DBUS_EXPORT
102 dbus_bool_t   dbus_message_set_path         (DBusMessage   *message,
103                                              const char    *object_path);
104 DBUS_EXPORT
105 const char*   dbus_message_get_path         (DBusMessage   *message);
106 DBUS_EXPORT
107 dbus_bool_t   dbus_message_has_path         (DBusMessage   *message, 
108                                              const char    *object_path);  
109 DBUS_EXPORT
110 dbus_bool_t   dbus_message_set_interface    (DBusMessage   *message,
111                                              const char    *iface);
112 DBUS_EXPORT
113 const char*   dbus_message_get_interface    (DBusMessage   *message);
114 DBUS_EXPORT
115 dbus_bool_t   dbus_message_has_interface    (DBusMessage   *message, 
116                                              const char    *iface);
117 DBUS_EXPORT
118 dbus_bool_t   dbus_message_set_member       (DBusMessage   *message,
119                                              const char    *member);
120 DBUS_EXPORT
121 const char*   dbus_message_get_member       (DBusMessage   *message);
122 DBUS_EXPORT
123 dbus_bool_t   dbus_message_has_member       (DBusMessage   *message, 
124                                              const char    *member);
125 DBUS_EXPORT
126 dbus_bool_t   dbus_message_set_error_name   (DBusMessage   *message,
127                                              const char    *name);
128 DBUS_EXPORT
129 const char*   dbus_message_get_error_name   (DBusMessage   *message);
130 DBUS_EXPORT
131 dbus_bool_t   dbus_message_set_destination  (DBusMessage   *message,
132                                              const char    *destination);
133 DBUS_EXPORT
134 const char*   dbus_message_get_destination  (DBusMessage   *message);
135 DBUS_EXPORT
136 dbus_bool_t   dbus_message_set_sender       (DBusMessage   *message,
137                                              const char    *sender);
138 DBUS_EXPORT
139 const char*   dbus_message_get_sender       (DBusMessage   *message);
140 DBUS_EXPORT
141 const char*   dbus_message_get_signature    (DBusMessage   *message);
142 DBUS_EXPORT
143 void          dbus_message_set_no_reply     (DBusMessage   *message,
144                                              dbus_bool_t    no_reply);
145 DBUS_EXPORT
146 dbus_bool_t   dbus_message_get_no_reply     (DBusMessage   *message);
147 DBUS_EXPORT
148 dbus_bool_t   dbus_message_is_method_call   (DBusMessage   *message,
149                                              const char    *iface,
150                                              const char    *method);
151 DBUS_EXPORT
152 dbus_bool_t   dbus_message_is_signal        (DBusMessage   *message,
153                                              const char    *iface,
154                                              const char    *signal_name);
155 DBUS_EXPORT
156 dbus_bool_t   dbus_message_is_error         (DBusMessage   *message,
157                                              const char    *error_name);
158 DBUS_EXPORT
159 dbus_bool_t   dbus_message_has_destination  (DBusMessage   *message,
160                                              const char    *bus_name);
161 DBUS_EXPORT
162 dbus_bool_t   dbus_message_has_sender       (DBusMessage   *message,
163                                              const char    *unique_bus_name);
164 DBUS_EXPORT
165 dbus_bool_t   dbus_message_has_signature    (DBusMessage   *message,
166                                              const char    *signature);
167 DBUS_EXPORT
168 dbus_uint32_t dbus_message_get_serial       (DBusMessage   *message);
169 DBUS_EXPORT
170 void          dbus_message_set_serial       (DBusMessage   *message, 
171                                              dbus_uint32_t  serial);
172 DBUS_EXPORT
173 dbus_bool_t   dbus_message_set_reply_serial (DBusMessage   *message,
174                                              dbus_uint32_t  reply_serial);
175 DBUS_EXPORT
176 dbus_uint32_t dbus_message_get_reply_serial (DBusMessage   *message);
177
178 DBUS_EXPORT
179 void          dbus_message_set_auto_start   (DBusMessage   *message,
180                                              dbus_bool_t    auto_start);
181 DBUS_EXPORT
182 dbus_bool_t   dbus_message_get_auto_start   (DBusMessage   *message);
183
184 DBUS_EXPORT
185 dbus_bool_t   dbus_message_get_path_decomposed (DBusMessage   *message,
186                                                 char        ***path);
187
188 DBUS_EXPORT
189 dbus_bool_t dbus_message_append_args          (DBusMessage     *message,
190                                                int              first_arg_type,
191                                                ...);
192 DBUS_EXPORT
193 dbus_bool_t dbus_message_append_args_valist   (DBusMessage     *message,
194                                                int              first_arg_type,
195                                                va_list          var_args);
196 DBUS_EXPORT
197 dbus_bool_t dbus_message_get_args             (DBusMessage     *message,
198                                                DBusError       *error,
199                                                int              first_arg_type,
200                                                ...);
201 DBUS_EXPORT
202 dbus_bool_t dbus_message_get_args_valist      (DBusMessage     *message,
203                                                DBusError       *error,
204                                                int              first_arg_type,
205                                                va_list          var_args);
206
207 DBUS_EXPORT
208 dbus_bool_t dbus_message_contains_unix_fds    (DBusMessage *message);
209
210 DBUS_EXPORT
211 dbus_bool_t dbus_message_iter_init             (DBusMessage     *message,
212                                                 DBusMessageIter *iter);
213 DBUS_EXPORT
214 dbus_bool_t dbus_message_iter_has_next         (DBusMessageIter *iter);
215 DBUS_EXPORT
216 dbus_bool_t dbus_message_iter_next             (DBusMessageIter *iter);
217 DBUS_EXPORT
218 char*       dbus_message_iter_get_signature    (DBusMessageIter *iter);
219 DBUS_EXPORT
220 int         dbus_message_iter_get_arg_type     (DBusMessageIter *iter);
221 DBUS_EXPORT
222 int         dbus_message_iter_get_element_type (DBusMessageIter *iter);
223 DBUS_EXPORT
224 void        dbus_message_iter_recurse          (DBusMessageIter *iter,
225                                                 DBusMessageIter *sub);
226 DBUS_EXPORT
227 void        dbus_message_iter_get_basic        (DBusMessageIter *iter,
228                                                 void            *value);
229 #ifndef DBUS_DISABLE_DEPRECATED
230 /* This function returns the wire protocol size of the array in bytes,
231  * you do not want to know that probably
232  */
233 DBUS_EXPORT
234 DBUS_DEPRECATED int         dbus_message_iter_get_array_len    (DBusMessageIter *iter);
235 #endif
236 DBUS_EXPORT
237 void        dbus_message_iter_get_fixed_array  (DBusMessageIter *iter,
238                                                 void            *value,
239                                                 int             *n_elements);
240
241
242 DBUS_EXPORT
243 void        dbus_message_iter_init_append        (DBusMessage     *message,
244                                                   DBusMessageIter *iter);
245 DBUS_EXPORT
246 dbus_bool_t dbus_message_iter_append_basic       (DBusMessageIter *iter,
247                                                   int              type,
248                                                   const void      *value);
249 DBUS_EXPORT
250 dbus_bool_t dbus_message_iter_append_fixed_array (DBusMessageIter *iter,
251                                                   int              element_type,
252                                                   const void      *value,
253                                                   int              n_elements);
254 DBUS_EXPORT
255 dbus_bool_t dbus_message_iter_open_container     (DBusMessageIter *iter,
256                                                   int              type,
257                                                   const char      *contained_signature,
258                                                   DBusMessageIter *sub);
259 DBUS_EXPORT
260 dbus_bool_t dbus_message_iter_close_container    (DBusMessageIter *iter,
261                                                   DBusMessageIter *sub);
262 DBUS_EXPORT
263 void        dbus_message_iter_abandon_container  (DBusMessageIter *iter,
264                                                   DBusMessageIter *sub);
265
266 DBUS_EXPORT
267 void dbus_message_lock    (DBusMessage  *message);
268
269 #ifdef ENABLE_KDBUS_TRANSPORT
270 DBUS_EXPORT
271 void dbus_message_unlock  (DBusMessage  *message);
272 #endif
273
274 DBUS_EXPORT
275 dbus_bool_t  dbus_set_error_from_message  (DBusError    *error,
276                                            DBusMessage  *message);
277
278
279 DBUS_EXPORT
280 dbus_bool_t dbus_message_allocate_data_slot (dbus_int32_t     *slot_p);
281 DBUS_EXPORT
282 void        dbus_message_free_data_slot     (dbus_int32_t     *slot_p);
283 DBUS_EXPORT
284 dbus_bool_t dbus_message_set_data           (DBusMessage      *message,
285                                              dbus_int32_t      slot,
286                                              void             *data,
287                                              DBusFreeFunction  free_data_func);
288 DBUS_EXPORT
289 void*       dbus_message_get_data           (DBusMessage      *message,
290                                              dbus_int32_t      slot);
291
292 DBUS_EXPORT
293 int         dbus_message_type_from_string (const char *type_str);
294 DBUS_EXPORT
295 const char* dbus_message_type_to_string   (int type);
296
297 DBUS_EXPORT
298 dbus_bool_t  dbus_message_marshal   (DBusMessage  *msg,
299                                      char        **marshalled_data_p,
300                                      int          *len_p);
301 DBUS_EXPORT
302 DBusMessage* dbus_message_demarshal (const char *str,
303                                      int         len,
304                                      DBusError  *error);
305
306 DBUS_EXPORT
307 int          dbus_message_demarshal_bytes_needed (const char *str, 
308                                                   int len);
309
310 /** @} */
311
312 DBUS_END_DECLS
313
314 #endif /* DBUS_MESSAGE_H */